日历程序设计文档.doc

  1. 1、本文档共28页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
日历程序设计文档

一、目的(要求) 日程序(日需包含以下三功能): 输出某年份的12个月 输出某年某月 输出某年某月某日是星期几 二、要 程序运行的流程: 始行的菜可: 输出某年份的12个月 输出某年某月 输出某年某月某日是星期几 程序行完成之后,可通用自己的意愿是否再行一次程序。 所包含的函数如下: 打印日的函:void printmonth(int m) 造日的函:void printheed(int m) int daysofmonth(int m) int isleep() int firstday(int m) void reset() void printweek(int d) int isleep(int s)(重函) 打印的函:void choose(int c) 三、要点 每个函数的功能: void printmonth(int m)作用:日的打印。 void printheed(int m)作用:造出日的“月 日 一 二 三 四 五 六”。 int daysofmonth(int m)作用:算m月的天。 int isleep()作用:判前年是否年。 int firstday(int m)作用:判m月的第一天是星期几。 void reset()作用:全局量初始。 void printweek(int d)作用:量化用可的“星期一,星期二”等可符。 int isleep(int s)作用:算N年到2012年中有多少年,且N2012时不包含2012年,N2012时包含2012年。 void choose(int c)作用:造程序部菜,面算机。 关键代码分析: 47~55:(此注代行,四、源程序,下同) int k=firstday(m) If(k==7)k=0; for(int i=0;ik;i++) cout” ”; for(int i=1;i=daysofmonth(m);i++) { cout” ”setw(2)i; if(k++==6){k=0;cout’\n’” ”;} } 此代中k(作用于printmonth的局部量)充星期几的角色,由k控制前出的日期是星期几。 64~82: { switch(m) case 1: case 3: case 5: case 7: case 8: case 10: case 12:return 31; case 4: case 6: case 9: case 11:return 30; case : if(isleep())return 29; else return 28; } } 由此代判m月有多少天,然后出,造日。2月通isleep()函判是否年。 89~119: { If(m==1) { If(yearN) { ynn=isleep(0)*366+((N-year)isleep(0))*365; weekday=7-7nn%7; } else { ynn=(isleep(0))*366+((year-N)-isleep(0))*365; weekday=7+ynn%7; if(weekday7)weekday-=7; } } else { if(year=N) { ynn+=daysofmonth(m-1); weekday=7+ynn%7; if(weekday7)weekday-=7; } else { ynn-=daysofmonth(m-1); weekday=7-ynn%7; } } return weekday; } 通算公式(天%7=距离2012年1月1日有几星期元)而算出m月的第一天是星期几。Isleep(0)通算之有多少年。通全局量weekday的return(可省略)出m月的第一天是星期几。 121~123: { ynn=0; } 全局量ynn初始,第二遍的行程序行准。 138~153: { int sum=0; if(Nyear) { for(int i=N;i=year;i++) if((i%4==0i100!=0)||(i%400==0))sum+=1; return sum; } else if(Nyear) { for(int i=N-1;i=year;i--) if((i%4==0i%100!=0)||(i%400==0))sum+=1; return sum; } else return 0; } 算返回sum(作用域isleep(int s))的(N年到2012年不包括2012年(2012年到N年)有多少年)。 155~200: { switch(c) { case 1: { 160~1

文档评论(0)

tmd2017 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档