打鱼还是晒网问题
中国有句俗语叫“三天打鱼两天晒网”。某人从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");}