发布时间:2025-12-10 19:14:14 浏览次数:14
C语言实现万年历(附代码)「建议收藏」C语言实现万年历具备知识1.公元1年1月1日是星期日。2.判断平年与闰年的方法。闰年:普通年需是4的整数倍,世纪年需是400的整数倍。平年:除去闰年的全是平年。3.平年2月有28天,闰年2月有29(特别说明:该日历第一天是按星期日开始的,如下图所示)检查平年闰年函数将判断平年闰年的语句封装成函数,便于调用。intcheck_year(intyear){//检查平年闰年函数 if(year%400==0){ return1;//闰年返回1 }else{ if(y
1.公元元1年1月1日是星期一(注:有说是星期六的,但从程序倒推回去是星期一,具体原因是一些历史问题,并不影响后续年份日历的呈现)。
教皇格里戈八世在1582年2月24日颁布法令,永远抹去了1582年10月5日到1582年10月14日。历史上从来不曾有过这10天。1582年10月4日是星期四,它的第二天是1582年10月15日星期五。
因此考虑到这10天的影响再去推算,公元元年1月1日就是星期六了。这里就以星期一进行计算。
2.判断平年与闰年的方法。
闰年:普通年需是4的整数倍,世纪年需是400的整数倍。
平年:除去闰年的全是平年。
3.平年2月有28天,闰年2月有29
(特别说明:该日历第一天是按星期日开始的,如下图所示)
将判断平年闰年的语句封装成函数,便于调用。
int check_year(int year){ //检查平年闰年函数if((year%400==0)||(year%4==0&&year%100!=0)){ return 1;//闰年返回1}else{ return 0;//平年返回0}}该函数计算该年以前的所有天数,并除7取余,即得到所要输出年1月1日是星期几(0:代表星期日)。
int week_f(int year){ //返回xx年1月1日是星期几 if(year==1){ //1年1月1日星期一return 1;}int sum=0;for(int i=1;i<year;i++){ if(check_year(i)==1){ sum=sum+366;} else{ sum=sum+365;}}return (sum+1)%7;}参数为月份。
如果是闰年则调用month_run(int n)。
否则调用month_ping(int n)。
int month_run(int n){ switch(n){ case 1:return 31;case 2:return 29;case 3:return 31;case 4:return 30;case 5:return 31;case 6:return 30;case 7:return 31;case 8:return 31;case 9:return 30;case 10:return 31;case 11:return 30;case 12:return 31;}}int month_ping(int n){ switch(n){ case 1:return 31;case 2:return 28;case 3:return 31;case 4:return 30;case 5:return 31;case 6:return 30;case 7:return 31;case 8:return 31;case 9:return 30;case 10:return 31;case 11:return 30;case 12:return 31;}}1.wee变量用于记录当前月的第一天是星期几。
下一月第一天的星期x=(上一月的星期x+上一月的天数)%7
wee=(wee+month_run(i))%7
2.enter变量用于检查什么时候换行,因为。
enter%7==0是换行条件
每月第一行时候需要加上前面的空格数量
在每个月输完enter需要减去下一个月的星期数,即
enter=enter-wee;
不然enter相当于加了两次星期数(第一次是在x个月最后一行,第二次是在x+1月的第一行空格处)。
void run(int week){ int enter=0;//记录换行 int wee=week;for(int i=1;i<=12;i++){ //最外层遍历12个月 printf("------>%d月<------\n",i);printf("日 一 二 三 四 五 六\n") ;//输出星期标头 for(int k=0;k<wee;k++){ //输出空格 printf(" ");enter++;} for(int j=1;j<=month_run(i);j++){ //输出每月的天 if(enter%7==0){ printf("\n");}printf("%d ",j);enter++;}wee=(wee+month_run(i))%7;enter=enter-wee;printf("\n\n\n"); }}#include<stdio.h>/*1.公元1年1月1日,是星期一 2.累加至输入年份之前的所有年的天数 3.总天数模7,0(星期日)---6(星期六) */int check_year(int year){ //检查平年闰年函数if((year%400==0)||(year%4==0&&year%100!=0)){ return 1;}else{ return 0;}}int week_f(int year){ //返回xx年1月1日是星期几if(year==1){ return 1;}int sum=0;for(int i=1;i<year;i++){ if(check_year(i)==1){ sum=sum+366;} else{ sum=sum+365;}}//printf("sum=%d\n",sum);return (sum+1)%7;}int month_run(int n){ switch(n){ case 1:return 31;case 2:return 29;case 3:return 31;case 4:return 30;case 5:return 31;case 6:return 30;case 7:return 31;case 8:return 31;case 9:return 30;case 10:return 31;case 11:return 30;case 12:return 31;}}int month_ping(int n){ switch(n){ case 1:return 31;case 2:return 28;case 3:return 31;case 4:return 30;case 5:return 31;case 6:return 30;case 7:return 31;case 8:return 31;case 9:return 30;case 10:return 31;case 11:return 30;case 12:return 31;}}///闰年输出函数 void run(int week){ int enter=0;//记录换行 int wee=week;for(int i=1;i<=12;i++){ //最外层遍历12个月 printf("------>%d月<------\n",i);printf("日 一 二 三 四 五 六\n") ;//输出星期标头 for(int k=0;k<wee;k++){ //输出空格 printf(" ");enter++;} for(int j=1;j<=month_run(i);j++){ //输出每月的天 if(enter%7==0){ printf("\n");}printf("%d ",j);enter++;}wee=(wee+month_run(i))%7;enter=enter-wee;printf("\n\n\n"); }}///平年输出函数void ping(int week){ int enter=0;//记录换行 int wee=week;for(int i=1;i<=12;i++){ //最外层遍历12个月 printf("------>%d月<------\n",i);printf("日 一 二 三 四 五 六\n") ;//输出星期标头 for(int k=0;k<wee;k++){ //输出空格 printf(" ");enter++;} for(int j=1;j<=month_ping(i);j++){ //输出每月的天 if(enter%7==0){ printf("\n");}printf("%d ",j);enter++;}wee=(wee+month_ping(i))%7;enter=enter-wee;printf("\n\n\n"); }}int main(){ int year;int week=0;int sum=0; printf("请输入年份:");scanf("%d",&year); week=week_f(year);if(check_year(year)==1){ run(week);} else{ ping(week);}return 0;}