打鱼还是晒网问题

来源:互联网 发布:阿里云电视猫 编辑:程序博客网 时间:2024/04/26 23:39

  打鱼还是晒网问题

  中国有句俗语叫“三天打鱼两天晒网”。某人从1990年1月1日起开始“三天打鱼两天晒网”,问这个人在以后的某一天中是“打鱼”还是“晒网”。

 问题分析:

1)计算从1990年1月1日开始至指定日期共有多少天;

2)由于“打鱼”和“晒网”的周期为5天,所以将计算出的天数用5去除;

3)根据余数判断他是在“打鱼”还是在“晒网”;

   若余数为1,2,3,则他是在“打鱼”,否则是在“晒网”

当然,最重要的是计算从1990年到指定日期的天数,这里涉及判断闰年的问题。

此处,先写函数判断某一年是否是闰年IsLeapYear(int year);

         然后给定年月、获得这个月的最大天数GetMaxDay(int year,int month)

        最后从1990年1月1日开始,一天一天的加,直到与指定的日期相等,算出加的天数即可。

C语言程序实现:

/* * 描述:"三天打鱼,两天晒网"解答 * 作者:张亚超 * 日期:2013/11/14 * Blog:http://blog.csdn.net/u012027907 */#include <stdio.h>//日期结构体typedef struct D{int year;int month;int day;}Date;//判断是否是闰年int IsLeapYear(int year){return (year % 400 == 0 || year % 4 == 0 && year % 100 != 0);}//获得某年某月的最大天数int GetMaxDay(int year,int month){switch(month){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 2:return IsLeapYear(year)?29:28;default:return -1;}}//两个日期是否相等int IsEqual(Date date1,Date date2){if(date1.year == date2.year && date1.month == date2.month && date1.day == date2.day)return 1;return 0;}//计算日期之间的天数差(一天一天加,直到相等,算出加的天数)int GetdiffDays(Date date1,Date date2){int X = 0;while(!IsEqual(date1,date2)){if(date1.day != GetMaxDay(date1.year,date1.month)){date1.day++;}else{if(date1.month != 12){date1.month++;date1.day = 1;}else{date1.day = date1.month = 1;date1.year++;}}X++;}return X;}void main(){    Date date1,date2;int X = 0;    date1.year = 1990;date1.month = 1;date1.day = 1;    printf("请输入日期:");scanf("%d%d%d",&date2.year,&date2.month,&date2.day);X = GetdiffDays(date1,date2);printf("日期差为:%d 天\n",X);X = X % 5; //天数对5取余if(X == 0 || X == 4) //余数为0、4,则为晒网printf("晒网!\n");elseprintf("打鱼!\n");}