Input
输入仅一行,输入年、月、日,用空格隔开。
Output
输出仅一行,该日是本年的第几天。
Sample Input
2000 5 8
Sample Output
129
思路分析
在本题中,需要我们计算一年的第几天,实质上题目要求我们计算求和。但是难点在于如何把每一年、平年、闰年、月份和日子加起来。
先对于年来说,需要编写一个函数去判断本年是平年还是闰年,即“四年一闰、百年不闰、四百年再润”,函数中传参传入年份,对4、100、400取余,符合上述标准的即是闰年,返回0或1即可。
再看月份,无非是30或31天,但是2月有28、29两种情况,就需要在先前判断好闰年的情况下再确定2月的具体天数。
最后是日,这一步比较简单,直接想加起来就完成。
代码实现
//1032 编写一个函数,给出年、月、日,计算该日是本年的第几天。
#include <stdio.h>
int main()
{
int sum = 0;
int yyyy = 0;//年
int mm = 0;//月
int dd = 0;//日
scanf("%d%d%d", &yyyy, &mm, &dd);
sum = sum_days(yyyy, mm, dd);
printf("%d", sum);
return 0;
}
int leap_year(int year)
{
if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0)//4年一润,百年不润,400年再润
{
return 1;//是闰年
}
else
return 0;//不是闰年
}
int month_days(int year, int month)//计算每月的天数,注意2月的不同
{
if (month == 1 || month == 3 || month == 5 || month == 7 || month == 8 || month == 10 || month == 12)
{
return 31;
}
if (month == 4 || month == 6 || month == 9 || month == 11)
{
return 30;
}
if (month == 2 && leap_year(year) == 1)
{
return 29;
}
if (month == 2 && leap_year(year) == 0)
{
return 28;
}
}
int sum_days(int year, int month, int day)
{
int i = 0;
int sum = 0;
for (i = 1; i < month; i++)
{
sum = sum + month_days(year, i);
}
sum = sum + day;
return sum;
}
注意
- 在编写函数类习题时,尽量使函数的功能最小化。函数的目的是简化问题,如果把函数功能扩大,不仅仅会冗杂,而且会减弱主函数存在的意义
- 上述代码中计算天数时,注意加的月份只需要加到前一个月。例如:求4月22日是2022年的第几天,只需要判断平闰年、从1月加到3月、再加22即可。
代码输出如下