这个题目是传统的打印日历的题目 不是很难 但要很细心 注意仔细观察样例的输出格式 才有可能AC 写的有点啰嗦了 如果有什么不对 欢迎大家批评指正
#include<iostream> #include<cstdio> #include<cstring> using namespace std; bool judge(int year)//判断是不是闰年 { if(year%4==0&&year%100!=0||year%400==0) return true; else return false; } int DaysReturn(int year,int month)//找出输入的日期的月份的一号距离2007年1月1日有多少天 { int sum=0;//统计一年内的天数 int sum1=0;//统计间隔了多少年的天数 if(judge(year)) { switch(month) { case 1: sum=0;break; case 2: sum=31;break; case 3: sum=31+29;break; case 4: sum=31+29+31;break; case 5: sum=31+29+31+30;break; case 6: sum=31+29+31+30+31;break; case 7: sum=31+29+31+30+31+30;break; case 8: sum=31+29+31+30+31+30+31;break; case 9: sum=31+29+31+30+31+30+31+31;break; case 10: sum=31+29+31+30+31+30+31+31+30;break; case 11: sum=31+29+31+30+31+30+31+31+30+31;break; case 12: sum=31+29+31+30+31+30+31+31+30+31+30;break; } } else { switch(month) { case 1: sum=0;break; case 2: sum=31;break; case 3: sum=31+28;break; case 4: sum=31+28+31;break; case 5: sum=31+28+31+30;break; case 6: sum=31+28+31+30+31;break; case 7: sum=31+28+31+30+31+30;break; case 8: sum=31+28+31+30+31+30+31;break; case 9: sum=31+28+31+30+31+30+31+31;break; case 10: sum=31+28+31+30+31+30+31+31+30;break; case 11: sum=31+28+31+30+31+30+31+31+30+31;break; case 12: sum=31+28+31+30+31+30+31+31+30+31+30;break; } } for(int i=2007;i<year;i++) { if(judge(i)) { sum1+=366; } else sum1+=365; } sum1+=sum;//总天数 return sum1; } void Print(int year,int days,int month) { int x=days%7+1;//找出这个月的1号是星期几 int monthdays;//这个月有多少天 cout<<"---------------------"<<endl; cout<<" Su Mo Tu We Th Fr Sa"<<endl; cout<<"---------------------"<<endl; if(month==2) { if(judge(year)) monthdays=29; else monthdays=28; } else if(month==4||month==9||month==6||month==11) { monthdays=30; } else monthdays=31; if(x==7) printf("%3d",1);//针对每个月一号不同的星期制定不同的输出格式 if(x==1) printf("%6d",1); if(x==2) printf("%9d",1); if(x==3) printf("%12d",1); if(x==4) printf("%15d",1); if(x==5) printf("%18d",1); if(x==6) printf("%21d",1); for(int i=2;i<=monthdays;i++) { printf("%3d",i); if((i+(x%7))%7==0&&i<monthdays) printf("\n");//注意如果一个月的最后一号是星期6则无需空行 } cout<<endl; cout<<"---------------------"<<endl; } int main() { int year,month; while(cin>>year>>month) { int days=DaysReturn(year,month); Print(year,days,month); } return 0; }
0.0分
0 人评分
C二级辅导-同因查找 (C语言代码)浏览:660 |
三角形 (C++代码)递推浏览:755 |
C语言训练-自由落体问题 (C语言代码)浏览:610 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:326 |
2^k进制数 (C语言描述,蓝桥杯)浏览:1420 |
C语言程序设计教程(第三版)课后习题6.1 (C语言代码)浏览:512 |
简单的a+b (C语言代码)浏览:462 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:525 |
用getchar()函数接收字符,正序输入为什么会倒序输出浏览:741 |
母牛的故事 (java语言代码)浏览:880 |