计算世界完全对称日的js代码,粗糙版_javascript技巧

比如20111102
下午闲着无聊,写了一个,代码没有经过优化,
只是凭着一股子无聊劲写出来的。
如果有哪位仁兄有兴趣把代码优化一下,感谢不尽

经过计算在公元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>

时间: 2024-08-02 22:01:53

计算世界完全对称日的js代码,粗糙版_javascript技巧的相关文章

Base64编码加密JS代码网页版_javascript技巧

Base64编码加密 Base64 原码 Base64 encode Base64 decode

3款实用的在线JS代码工具(国外)_javascript技巧

   1. 压缩工具        用于在线压缩你的JS代码,它有一个选项"Include latest jquery.min.js",这对于提升速度非常有用.         推荐理由:缩小代码 = 更小的文件大小 = 更快的网页加载速度           2. 美化工具          用于将压缩后的代码转换回正常状态,使代码再次可读.该工具也可用于混淆的代码.         推荐理由:漂亮的代码 = 易读 = 更快地开发         3. 混淆工具        用于保

文本框只能输入数字的js代码(含小数点)_javascript技巧

只能输入0-9多包括小数点 <html> <head> <meta http-equiv="content-Type" content="text/html;charset=gb2312"> <title>js 只能输入数字和小数点</title> <script language="JavaScript" type="text/javascript">

Google的跟踪代码 动态加载js代码方法应用_javascript技巧

复制代码 代码如下: <script type="text/javascript"> var _gaq = _gaq || []; //如果变量 _gaq 存在,就等于他自己,否则为一个空数组 _gaq.push(['_setAccount', 'UA-24479793-2']); //是个2维数组 _gaq[0] = array(0=>'_setAccount', 1=>'UA-24479793-2');(设置本跟踪代码所对应的Google帐户) _gaq.p

不用一句js代码初始化组件_javascript技巧

最近使用bootstrap组件的时候发现一个易用性问题,很多简单的组件初始化都需要在JS里面写很多的初始化代码,比如一个简单的select标签,因为仅仅只是需要从后台获取数据填充到option里面,可是从后台取数据就需要js的初始化,所以导致页面初始化的时候js的初始化代码里面出现很多重复的代码,看着很闹心.于是想起bootstrap table里面的data属性来,如果能够直接在html里面使用data-*这种方式来初始化简单的组件,那该多爽.我们先来看看bootstrap table的文档:

8 行 Node.js 代码实现代理服务器_javascript技巧

接触 Node.js 已有多年,一直喜欢它的单线程模型和异步IO特性,以及 JavaScript 语言本身的灵活性.同时,JavaScript 前后端通吃,在全栈开发领域具有独特的优势.今天就来看看作为服务端语言的 JavaScript,完成一个简单的代理服务器功能是多么容易. 简单地说,代理服务器就是代理用户访问目标站点的中介服务器.作为前端开发人员,代理的常见用途是跨域访问后台 API.当然,还可以用来科学上网.今天要分享的代码,就是跟科学上网有关. 话不多说,先上 code: var ex

js tab效果代码增强版_javascript技巧

热门图片   波希米亚   红色黑客       正在加载... [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] 本人在它的基础上添加的内容控制的效果 复制代码 代码如下: <script type="text/javascript"> function $(objName) {     if(document.getElementById)     {         return document.getElementById(objName );     

获取数组中最大最小值方法js代码(自写)_javascript技巧

现在获取数组中最大最小值用的越来越多了,于是乎我编了个方法供大家使用.代码如下,若有问题可以与我联系,咱们一起学习一起进步. 复制代码 代码如下: function getMaximin (arr,maximin) { if (maximin == "max") { return Math.max.apply(Math, arr); }else if (maximin == "min") { return Math.min.apply(Math, arr); } }

JS代码混淆初步_javascript技巧

/* 这个是一个类 */ function xx(num,str) { //说明 var a = num; this.aa = a; this.bb = function(){alert(str);} this.cc = function(){for(var i=0;i<10;i++){document.title=i;}} } xx.prototype.dd= function(){ alert("dd"); } var a = new xx(100,"hello&q