/*
中国有句俗语叫―三天打鱼两天晒网‖。某人从 1990 年 1 月 1 日起开始―三天打鱼两天晒网‖,
问这个人 在以后 的某一 天中是 ―打鱼 还是―晒网。
分析:
1) 计算从 1990 年 1 月 1 日开始至指定日期共有多少天;
2) 由于―打鱼‖和―晒网‖的周期为 5 天,所以将计算出的天数用5 去除;
3) 根据余数判断他是在―打鱼还是在―晒网;
若余数为 1,2,3,则他是在―打鱼‖
否则 是在―晒网‖
在这三步中,关键是第一步。
求从 1990 年 1 月 1 日至指定日期有多少天,要判断经历年份中是否有闰年,二月为 29 天,平年为 28 天。
闰年的方法可以用伪语句描述如下:
如果 ((年能被 4除尽 且 不能被 100除尽)或 能被400除尽)
则 该年是闰年;
否则 不是闰年。
C 语言中判断能否整除可以使用求余运算(即求模)
*/
#include <stdio.h>
int days(struct date day);
struct date{
int year;
int month;
int day;
};
int main()
{
struct date today,term;
int yearday,year,day;
printf("Enter year month day:"); // 输入例子 2014 5 6
scanf("%d%d%d",&today.year,&today.month,&today.day); /*输入日期*/
term.month = 12; /*设置变量的初始值:月*/
term.day = 31; /*设置变量的初始值:日*/
for( yearday = 0, year = 1990; year < today.year ; year++ )
{
term.year = year;
yearday += days(term); /*计算从 1990 年至指定年的前一年共有多少天*/
}
yearday += days(today); /*加上指定年中到指定日期的天数*/
day = yearday%5; /*求余数*/
if( day > 0 && day < 4 )
printf("he was fishing at that day.\n"); /*打印结果*/
else
printf("He was sleeping at that day.\n");
}
int days(struct date day)
{
static int day_tab[2][13]= {
{0,31,28,31,30,31,30,31,31,30,31,30,31,}, /*平均每月的天数*/
{0,31,29,31,30,31,30,31,31,30,31,30,31,},
};
/*判定 year 为闰年还是平年,lp=0 为平年,非 0 为闰年*/
bool lp = (day.year%4 == 0 && day.year % 100 != 0 )|| day.year%400 == 0;
for(int i = 1; i < day.month; i++ ) /*计算本年中自 1 月 1 日起的天数*/
day.day += day_tab[lp][i];
return day.day;
}