题目 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;
}
相关推荐
abant23 分钟前
leetcode 45 跳跃问题2 很难的贪心
算法·leetcode·职场和发展
小糯米6014 分钟前
C语言指针3
c语言·数据结构·算法
ZPC82109 分钟前
ROS2 通信提速快过UDP
人工智能·算法·机器人
RD_daoyi11 分钟前
谷歌2026年 3 月核心更新深度解析:SEO 从内容优化到信息供给系统的全面重构
人工智能·算法·重构
Xiu Yan19 分钟前
Java 转 C++ 系列:函数对象、谓词和内建函数对象
java·开发语言·c++
Full Stack Developme22 分钟前
Hutool StrUtil 教程
开发语言·网络·python
代码羊羊22 分钟前
Rust方法速览:从self到impl
开发语言·后端·rust
lkforce23 分钟前
MiniMind学习笔记(零)--基础概念
人工智能·算法·机器学习·token·分词器·minimind·词汇表
6Hzlia24 分钟前
【Hot 100 刷题计划】 LeetCode 94. 二叉树的中序遍历 | C++ 递归法 & 迭代法
算法
nike0good27 分钟前
The 4th Universal Cup GP of Kyoto, April 4-5, 2026 题解
算法·深度优先·图论