目录
点击下方链接开始做本题:
一、描述
根据输入的日期,计算是这一年的第几天。
保证年份为4位数且日期合法。
进阶:时间复杂度:O(n)\O(n) ,空间复杂度:O(1)\O(1)
输入描述:
输入一行,每行空格分割,分别是年,月,日
输出描述:
输出是这一年的第几天
二、思路:
这道题简单解法其实将每个月的天数枚举出来,然后根据当前月份向前累加满月的天数,然后再加上当前月所在的天数。最终考虑平闰年的 2 月份区别是否增加一天。 其中需要注意的是平年和闰年的判断,而且是闰年的月份大于 2 的时候,也就是 2 月走完,总天数才能加 1 (比如 2000年2月18日 ,虽然是闰年,但是 2月 都没走完那是不能加上闰年多出的一天的)。
三、代码实现
执行代码如下:
#include <stdio.h>
int main()
{
int year,month,day,sum,ret;
int arr[12]={0,31,28,31,30,31,30,31,31,30,31,30,31};
while((scanf("%d%d%d",&year,&month,&day))!=EOF)
{
sum=day;//先将本月天数加上
if (is_leap_year(year) && month > 2)
{
sum += 1;
}
for(int i=0;i<month;i++)
{
sum+=arr[i];//将所有月份累加
}
printf("%d",sum);
}
}
int is_leap_year(int y)//判断是否闰年
{
if (y % 4 == 0 && y % 100 != 0 || y % 400 == 0)
{
return 1;
}
return 0;
}