• T1175计算两个日期之间的天数


    【题目来源】https://www.jisuanke.com/problem/T1175
    蒜头君给定两个日期,请计算相差的天数。比如2010-1-1和2010-1-3相差2天。
    【输入格式】
    共两行:第一行包含三个整数startYear,startMonth,startDay,分别是起始年、月、日。第二行包含三个整数endYear,endMonth,endDay,分别是结束年、月、日。相邻两个整数之间用单个空格隔开。年份范围在1~3000。保证日期正确且结束日期不早于起始日期
    【输出格式】
    输出一个整数,即是两个日期相差的天数。

    # include 
    // 定义结构体表示日期类型
    typedef struct Date {
        int y, m, d;
    }Date;
    // 判断是否是闰年的函数
    int isleapyear(int y)
    {
        int ret = 0;
        if (y % 4 == 0 && y % 100 != 0 || y % 400 == 0)
            ret = 1;
        return ret;
    }
    int main()
    {
        Date start, end;
        scanf("%d%d%d", &start.y, &start.m, &start.d);
        scanf("%d%d%d", &end.y, &end.m, &end.d);
        int table[2][12] = {{31,28,31,30,31,30,31,31,30,31,30,31}, {31,29,31,30,31,30,31,31,30,31,30,31}};
        int days = 0;
        // 计算相差多少个整年
        for (int i = start.y + 1; i < end.y; ++i) {
            int flg = 0;
            if (isleapyear(i)){
                flg = 1;
            }
            for (int j = 0; j < 12; ++j)
                days += table[flg][j];
        }
        // 计算起始年到这一年结束还有多少天
        int flg = isleapyear(start.y);
        for (int i = 12; i > start.m; --i)
            days += table[flg][i - 1];
        days += (table[flg][start.m - 1] - start.d);
        
        // 计算结束年从这一年开始过去了多少天
        flg = isleapyear(end.y);
        for (int i = 1; i < end.m; ++i)
            days += table[flg][i - 1];
        days += end.d;
        
        printf("%d", days);
        return 0;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
  • 相关阅读:
    Visual Studio2019 与 MySQL连接 版本关系
    【4.3 分布形态的描述】(描述性统计分析)——CDA
    C++学习之路-智能指针
    ChatGPT AIGC 一键总结SQL优化所有知识点
    THREEJS 性能优化
    y115.第七章 服务网格与治理-Istio从入门到精通 -- 云原生概念(一)
    Android 9.0 蓝牙功能之一:蓝牙电话
    微服务架构
    Redis数据类型
    CentOS 7:服务器环境搭建
  • 原文地址:https://blog.csdn.net/dream_aleaf/article/details/134043005