题解 | #今年的第几天?#

今年的第几天?

https://www.nowcoder.com/practice/ae7e58fe24b14d1386e13e7d70eaf04d

注意!只有月份大于2 或 日期为2.29 时 需要判断是否是闰年

  1. 创建月份数组,保存每个月有多少天;
  2. 判断是否是闰年,如果是则run=1,否则run=0;
  3. 循环i,计算从1月~month-1月一共有多少天,再加上day和run的值,就是所求的值。
#include <iostream>
using namespace std;
int mon[12]= {31,28,31,30,31,30,31,31,30,31,30,31};

int main() {
    int year, month, day;
    while (cin >> year >> month >> day) { // 注意 while 处理多个 case
        //判断是否是闰年
        int run = 0;
        if (month > 2 || month == 2 && day == 29)
            if (year % 4 == 0 && year % 100 != 0 || year %400 == 0)
                run = 1;

        for (int i = 0; i < month-1; i++){
            day += mon[i];
        }
        cout << day+run << endl;
    }
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

11-08 13:58
门头沟学院 Java
程序员小白条:竟然是蓝桥杯人才doge,还要花钱申领的offer,这么好的公司哪里去找
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务