题目 1049: [编程入门]结构体之时间设计

定义一个结构体变量(包括年、月、日)。计算该日在本年中是第几天,注意闰年问题。

输入格式

年月日

输出格式

当年第几天

样例输入

复制代码
2000 12 31

样例输出

复制代码
366

定义时间的结构体,详情见下一篇文章关于结构体的写法;

判断是否为闰年有一个布尔值,用于变量temp是29(闰年)还是28(不是闰年),之后累加计算是多少天

cpp 复制代码
#include <iostream>

// 计算输入日期是一年中的第几天
int CalcuCount(int year, int month, int day) {
    int Count = 0;
    // 判断闰年
    bool isleap;
    if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0) {
        // 如果是闰年,则有366天
        isleap = true;
    } else {
        // 如果不是闰年,则有365天
        isleap = false;
    }

    if (month == 2) {
        // 对于2月份,加上当前的天数即可
        Count = 31 + day;
    } else {
        // 如果是其他月份
        int temp = 0;
        if (isleap){
            // 如果是闰年,则2月有29天
            temp = 29;
        } else { 
            // 如果不是闰年,则2月有28天
            temp = 28;
        }
        
        // 利用temp来计算累积天数
        switch (month) {
            // 对于1、3、5、7、8、10、12月,则累积天数为当前月的天数加上之前的月份天数
            case 1: Count = day; break;
            case 3: Count = 31 + temp + day; break;
            case 4: Count = 62 + temp + day; break;
            case 5: Count = 92 + temp + day; break;
            case 6: Count = 123 + temp + day; break;
            case 7: Count = 153 + temp + day; break;
            case 8: Count = 184 + temp + day; break;
            case 9: Count = 215 + temp + day; break;
            case 10: Count = 245 + temp + day; break;
            case 11: Count = 276 + temp + day; break;
            case 12: Count = 306 + temp + day; break;
        }
    }
    return Count;
}

struct Date {
    int year;
    int month;
    int day;
};

int main() {
    struct Date date;
    std::cin >> date.year >> date.month >> date.day;
    std::cout << CalcuCount(date.year, date.month, date.day) << std::endl;
    return 0;
}
相关推荐
爱吃烤鸡翅的酸菜鱼几秒前
IDEA高效开发:Database Navigator插件安装与核心使用指南
java·开发语言·数据库·编辑器·intellij-idea·database
呆呆的小鳄鱼19 分钟前
leetcode:冗余连接 II[并查集检查环][节点入度]
算法·leetcode·职场和发展
墨染点香19 分钟前
LeetCode Hot100【6. Z 字形变换】
java·算法·leetcode
沧澜sincerely20 分钟前
排序【各种题型+对应LeetCode习题练习】
算法·leetcode·排序算法
CQ_071220 分钟前
自学力扣:最长连续序列
数据结构·算法·leetcode
弥彦_36 分钟前
cf1925B&C
数据结构·算法
心情好的小球藻38 分钟前
Python应用进阶DAY9--类型注解Type Hinting
开发语言·python
惜.己1 小时前
使用python读取json数据,简单的处理成元组数组
开发语言·python·测试工具·json
Y4090011 小时前
C语言转Java语言,相同与相异之处
java·c语言·开发语言·笔记
YuTaoShao1 小时前
【LeetCode 热题 100】994. 腐烂的橘子——BFS
java·linux·算法·leetcode·宽度优先