万年历C语言设计_第1页
万年历C语言设计_第2页
万年历C语言设计_第3页
已阅读5页,还剩10页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、万年历的设计:要求:模仿现实生活中的挂历,能够显示年历、月历、日历,并具备退出功能。当前页以系统当前日期的月份为准显示当前月的每一天(显示出日及对应的星期几)。当系统日期变到下一月时,系统自动 翻页到下一月。万年历的程序流程图:主要程序流程图:具体对于月份和年份的程序图如下1TntT, j=L k=1,mOnth, year;Print fl ":.山;S.70Printl( in")V 7FtlntfC "<bi=7+k-aPr im r( -Ni=7+k-a上图为计算星期方法上图为打印日历程序图万年历的设计的程序源代码:#include <stdi

2、o.h>#include <stdlib.h>#include <ctype.h>void f()int day,month,year,sum,leap,S; printf("n 请输入年月日 n"); scanf("%d%d%d",&year,&month,&day);while(1) if(month>12|month<1)|(day>31|day<1)printf(" 输入错误,重新输入 "); scanf("%d%d%d",&am

3、p;year,&month,&day);else break; switch(month)case 1:sum=0;break;case 2:sum=31;break;case 3:sum=59;break;case 4:sum=90;break;case 5:sum=120;break;case 6:sum=151;break;case 7:sum=181;break;case 8:sum=212;break;case 9:sum=243;break;case 10:sum=273;break;case 11:sum=304;break;case 12:sum=334;bre

4、ak; default:printf("data error");break;sum=sum+day; if(year%400=0|(year%4=0&&year%100!=0) leap=1;else leap=0; if(leap=1&&month>2) sum+;S=(year-1+(year-1)/4-(year-1)/100+(year-1)/400+sum)%7; switch(S)星期一 n");break 星期二 n");break 星期三 n");break 星期四 n");br

5、eak 星期五 n");break 星期六 n");break 星期日 n");breakcase 1:printf(" case 2:printf(" case 3:printf(" case 4:printf(" case 5:printf(" case 6:printf(" case 0:printf(" void g()int i,j=1,k=1,a,b,month,year; printf("n 输入年月 :n"); scanf("%d%d",&

6、amp;year,&month); while(1)if(month>12|month<1)printf(" 输入错误,重新输入 "); scanf("%d%d",&year,&month); else break;b=days_month(month,year); a=firstday (month,year);printf("f*n");printf(" Sun Mon Tue Wed Thu Fri Sat n"); if(a=7) for(i=1;i<=b;i+)p

7、rintf("%4d",i); if(i%7=0) printf("n");if(a!=7)while (j<=4*a) printf(" ");j+;for(i=1;i<=b;i+) printf("%4d",i);if(i=7*k-a)printf("n");k+;printf("n*n");printf("n"); int leap (int year) if(year%4=0&&year%100!=0|year%400=

8、0) return 1;else return 0;int days_month (int month,int year)if(month=1|month=3|month=5|month=7|month=8|month=10|month=12)return 31; if(month=4|month=6|month=9|month=11)return 30;if(month=2&&leap(year)=1) return 29;else return 28;int firstday(int month,int year)int W;W=(1+2*month+3*(month+1)

9、/5+year+year/4+year/400-year/100)%7+1; return W;void h()int i,j=1,k=1,a,b,month,year,g; printf("n 输入任意年 :n"); scanf("%d",&year);for(g=0;g<=11;g+)month=g+1;b=days_month(month,year);a=firstday (month,year); prin tf("%d月 n",mo nth);printf("f*n");printf(&qu

10、ot; Sun Mon Tue Wed Thu Fri Sat n"); if(a=7)for(i=1;i<=b;i+)printf("%4d",i); if(i%7=0) printf("n");j=1;k=1;if(a!=7)while (j<=4*a)printf(" "); j+; for(i=1;i<=b;i+) printf("%4d",i);if(i=7*k-a) printf("n"); k+;printf("n*n");print

11、f("n");void main()for(;)switch(menu_select()case 1:printf(" 输入年月日计算星期几 n");f(); break;case 2:printf(" 打印任意日历 n");g(); break;case 3:printf(" 打印任意年历 n");h(); break;case 4:printf(" 谢谢使用 !n");exit(0);算星期雷历 H mm;年? 月 2 用4: 年i年 八?五入印肾t输13期 请2B星勺2.3.4.inint

12、 menu_select() _char S;int cn;printf("1.输入年月日计算星期几n");printf("2.打印任意月历n");printf("3.打印任意年历n");printf("4.谢谢使用! n");prin tf("i nput 1-4:n");do S=getchar();cn=(i nt)S-48;while(cn<0|cn>6);return cn;万年历的运行结果截图万年历的日历功能的实现:"l:cDe bu gwa n gn i an

13、li. exeR4T-谢input加人年月日计算星期几月历功能的实现:"l:cDe bu gwangnianli.exenB n 12 3 4.丁印任意日历输入年月:2013 ?SunHonTue27 14 21 2fl3 IQ 17 24 31Thu4111825FriSat121926132027几 期 星 算 计历历日月年!月二曇耳用4:年4W1- 人印t年历功能的实现:"I:cDebugwjngr anli.exe晒历历 日月年? 月二餐用4: 年wl- 人印t VIblln L± 2 3 4 i側入任忌、年:2013I月SunMonTueUedThuFriSat16101711192627142128293031迈月电# H4卫电4 b_il4# * b电* FJI *电4Jb_jfl, ifcj t 4J 电超*j W,bj|n n n n -fSunMonTueWedThuw n* e e Frin n n n n n n n -n n

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论