Bootstrap

C语言初阶牛客网刷题——HJ73 计算日期到天数转换【难度:简单】

1. 题目描述——HJ73 计算日期到天数转换

牛客网OJ题链接

描述

每一年中都有 12 个月份。其中,1,3,5,7,8,10,12 月每个月有 31 天;
4,6,9,11 月每个月有 30 天;而对于 2 月,闰年时有29 天,平年时有 28 天。
现在,对应输入的日期,计算这是这一年的第几天。

一个年份是闰年当且仅当它满足下列两种情况其中的一种:
∙这个年份是 4 的整数倍,但不是 100 的整数倍;
∙这个年份是 400400 的整数倍。
输入描述:
在这里插入图片描述
输出描述:
输出一个整数,代表输入的日期是这一年的第几天。

示例1
输入:2012 12 31
输出:366
说明:2012 年是闰年,因此2012年12月31 日是这一年的第 366 天。

示例2
输入:1982 3 4
输出:63

2. 思路

之前做过牛客网刷题 ——C语言初阶(5操作符)——BC54 获得月份天数
就是在获取到每个月的基础上,在for循环加一下每个月的天数即可

3. 代码实现

#include <stdio.h>

int isLeapYear(int year)
{
    if((year%4==0&&year%100!=0)||year%400 ==0)
    {
        return 1;
    }
    return 0;
}
int main() {
    int year, mouth,day;
    int days[]= {0, 31,28,31,30,31,30,31,31,30,31,30,31 };
    while (scanf("%d %d %d", &year, &mouth,&day) != EOF) { 
        int totalDay = day;
        int day = days[mouth];
        if(isLeapYear(year)&&mouth>2)
        {
            totalDay+=1;
        }
        int i  = 0;
        for(i = mouth-1;i>0;i--)
        {
            totalDay += days[i];
        }

        printf("%d",totalDay);
    }
    return 0;
}

在这里插入图片描述

悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;