计算世界完全对称日的js方法,粗糙版
来源:广州中睿信息技术有限公司官网
发布时间:2012/10/21 23:25:16 编辑:admin 阅读 247
世界完全对称日,指的是公历纪年日期中数字左右完全对称的日期,这一天朋友们可以互送祝福同时让大家感叹时间的宝贵。比如今天下午闲着无聊,写了一个,代码没有经过优化,只是凭着一股子无聊劲写出来的。如果有哪
世界完全对称日,指的是公历纪年日期中数字左右完全对称的日期,这一天朋友们可以互送祝福同时让大家感叹时间的宝贵。

比如今天

 

下午闲着无聊,写了一个,代码没有经过优化,

只是凭着一股子无聊劲写出来的。

如果有哪位仁兄有兴趣把代码优化一下,感谢不尽

 

经过计算在公元2000年到3000年,一共有36个符合条件的世界完全对称日。

 见到园子里有的博客,可以在下面加“运行”,直接执行Html代码,不知道怎么整的,可有人告知一下

 

<!DOCTYPE HTML>
<html>
  <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>公元1000年以后的回文日</title>
    <script>
        /**
         * 将日期变为标准8位格式,如20111102
         * 将其分为四段 分别为 20 11 11 02 为世纪,年,月,日
         * 按年算法时间复杂度为O(n3),而从后四位,月日即可得到最后的结果,效率更高
         * 因为闰年2月尾数为9,超过人类漫长的历史,所以无须考虑
         
*/
        ;;(function(){
            var theDateList=[];
            //出现回文日的世纪最大值
            var maxForCentury=30;
            //出现回文日的世纪最小值
            var minForCentury=20;
            //可能出现回文日的年数最大值,这里只粗糙处理
            var maxForYear=21;
            var maxForDay=31;//不排除闰年
            for(var i=1;i<=12;i++){
                var stdYear,stdDay;
                var stdMonth=getStandardDate(i);
                /*
                if(getReverseDate(stdMonth)>maxForDay){
                    continue;
                }
                
*/
                maxForDay=getDate(i);
                for(var k=1;k<maxForDay;k++){
                    stdDay =getStandardDate(k);
                    stdYear=getReverseDate(stdMonth+stdDay);
                    if(parseInt(getReverseDate(stdDay),10)>=minForCentury
                        && parseInt(getReverseDate(stdDay),10)<maxForCentury)
                    theDateList.push(stdYear+stdMonth+stdDay)
                }
                
            }
            theDateList.sort(); //排序
            for(var i=0;i<theDateList.length;i++){
                console.log(theDateList[i]);
            }
            console.log('共有%d条记录',theDateList.length)
            /**
             * 根据月份算当前月天数
             * @param {int} val 月份
             * @return {int} 
             
*/
            function getDate(val){
                return val%2==0?30:31;
            }
            /**
             * 将小于10的日期值换成标准8位日期值
             * @param {int} val 月份或日期
             * @return {string} 标准格式
             
*/
            function getStandardDate(val){
                if(val<10){
                    return '0'+val;
                }
                return val.toString();
            }
            /**
             * 反转日期
             * @param {string} date 月份或日期的标准格式
             * @return {string} 反转后的标准格式
             
*/
            function getReverseDate(date){
                return date.split("").reverse().join("");
            }
        })();
    </script>
</head>
    <body>
    </body>
    </html> 
联系我们CONTACT 扫一扫
愿景:成为最专业的软件研发服务领航者
中睿信息技术有限公司 广州•深圳 Tel:020-38931912 务实 Pragmatic
广州:广州市天河区翰景路1号金星大厦18层中睿信息 Fax:020-38931912 专业 Professional
深圳:深圳市福田区车公庙有色金属大厦509~510 Tel:0755-25855012 诚信 Integrity
所有权声明:PMI, PMP, Project Management Professional, PMI-ACP, PMI-PBA和PMBOK是项目管理协会(Project Management Institute, Inc.)的注册标志。
版权所有:广州中睿信息技术有限公司 粤ICP备13082838号-2