C语言 万年历程序
原代码:
chunli@Linux:~/c++$ cat 123.c #include#define Mon 1 #define Tues 2 #define Wed 3 #define Thur 4 #define Fri 5 #define Sat 6 #define Sun 0 #define January_days 31 #define February_days 28 #define March_days 31 #define April_days 30 #define May_days 31 #define June_days 30 #define July_days 31 #define August_days 31 #define September_days 30 #define October_days 31 #define November_days 30 #define December_days 31 #define first1month January_days #define first2month January_days+February_days #define first3month January_days+February_days+March_days #define first4month January_days+February_days+March_days+April_days #define first5month January_days+February_days+March_days+April_days+May_days #define first6month January_days+February_days+March_days+April_days+May_days+June_days #define first7month January_days+February_days+March_days+April_days+May_days+June_days+July_days #define first8month January_days+February_days+March_days+April_days+May_days+June_days +July_days+August_days #define first9month January_days+February_days+March_days+April_days+May_days+June_days +July_days+August_days+September_days #define first10month January_days+February_days+March_days+April_days+May_days+June_days+July_days+August_days+September_days+October_days #define first11month January_days+February_days+March_days+April_days+May_days+June_days+July_days+August_days+September_days+October_days+November_days int known_weekday = Tues; int known_year = 1901; int konwn_month = 1; int known_day = 1; int day_count(int month) { switch(month) { case 1: return 0;break; case 2: return first1month;break; case 3: return first2month;break; case 4: return first3month;break; case 5: return first4month;break; case 6: return first5month;break; case 7: return first6month;break; case 8: return first7month;break; case 9: return first8month;break; case 10: return first9month;break; case 11: return first10month;break; case 12: return first11month;break; } } char * month_name(int month) { switch(month) { case 1: return "一月"; break; case 2: return "二月"; break; case 3: return "三月"; break; case 4: return "四月"; break; case 5: return "五月"; break; case 6: return "六月"; break; case 7: return "七月"; break; case 8: return "八月"; break; case 9: return "九月"; break; case 10: return "十月"; break; case 11: return "十一月"; break; case 12: return "十二月"; break; default: break; } } /*按格式打印某年某月名称*/ void first_line_print(int month, int year) { //printf("%20s %d \n",month_name(month),year); printf("%8d年 %s \n",year, month_name(month)); } /*按格式打印星期名称*/ void week_print() { //printf("%-6s%-6s%-6s%-6s%-6s%-6s%-6s\n","Sun.", "Mon.", "Tues.", "Wed.", "Thur.", "Fri.", "Sat."); printf("%-4s%-4s%-4s%-4s%-4s%-4s%-4s\n","日", "一", "二", "三", "四", "五", "六"); } /*计算该年该月份与已知日子之间的距离天数*/ int date_distance_count(int month, int year) { int leap_year_count = 0; int i; int distance; if (year > known_year) { for (i=known_year; i 2) { if(((year%4 == 0) && (year%100 != 0) ) || (year%400 == 0)) { leap_year_count++; } } } else if (year == known_year) { if (month > 2) { leap_year_count = 1; } } distance = (year - known_year)*365 + leap_year_count + day_count(month); return distance; } /*确定该月份第一天是星期几*/ int makesure_firstday_weekday(int month, int year) { int date_distance = 0; int weekday; date_distance = date_distance_count(month, year); weekday = (known_weekday + date_distance)%7; return weekday; } /*依次打印出该月份的日子*/ void print_in_turn(int month, int firstday, int year) { int i = 1; int weekday; switch(firstday) { case Sun: break; case Mon: printf("%-3s",""); break; case Tues: printf("%-6s",""); break; case Wed: printf("%-9s",""); break; case Thur: printf("%-12s",""); break; case Fri: printf("%-15s",""); break; case Sat: printf("%-18s",""); break; } switch(month) { case 1: case 3: case 5: case 7: case 8: case 10: case 12: { for(i=0; i<31; i++) { weekday = (firstday + i)%7; printf("%-3d",i+1); if(weekday == Sat) { printf("\n"); } } break; } case 2: { if(((year%4 == 0) && (year%100 != 0) ) || (year%400 == 0)) /*闰年*/ { for(i=0; i<29; i++) { weekday = (firstday + i)%7; printf("%-3d",i+1); if(weekday == Sat) { printf("\n"); } } break; } else /*平年*/ { for(i=0; i<28; i++) { weekday = (firstday + i)%7; printf("%-3d",i+1); if(weekday == Sat) { printf("\n"); } } break; } } case 4: case 6: case 9: case 11: { for(i=0; i<30; i++) { weekday = (firstday + i)%7;/*计算该天是星期几*/ printf("%-3d",i+1); if(weekday == Sat) { printf("\n");/*如果是星期六,则换行*/ } } break; } } } void date_print(int month, int year) { int firstday; firstday = makesure_firstday_weekday(month, year); print_in_turn(month, firstday, year); printf("\n"); } void main_month(int month, int year) { first_line_print(month, year); week_print(); date_print(month, year); printf("\n\n"); } void main_calendar(int year) { int i; for(i=1; i<=12; i++) { main_month(i, year); } } int main() { int year; printf("请输入年份:year = "); scanf("%d",&year); printf("\n"); while(year < 1902) { printf("请输入大于1901的年份\n"); printf("请输入年份:year = "); scanf("%d",&year); printf("\n"); } main_calendar(year); return 0; } chunli@Linux:~/c++$
编译运行:
chunli@Linux:~/c++$ gcc 123.c && ./a.out 请输入年份:year = 2016 2016年 一月 日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 2016年 二月 日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 2016年 三月 日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 2016年 四月 日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 2016年 五月 日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 2016年 六月 日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 2016年 七月 日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 2016年 八月 日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 2016年 九月 日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 2016年 十月 日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 2016年 十一月 日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 2016年 十二月 日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 chunli@Linux:~/c++$