牛客网KY258 日期累加

题目

描述:

设计一个程序能计算一个日期加上若干天后是什么日期。

输入描述:

输入第一行表示样例个数m,接下来m行每行四个整数分别表示年月日和累加的天数。

输出描述:

输出m行,每行按yyyy-mm-dd的个数输出。

题解

直接简单的思路:首先累加的天数(days)减去当前月份剩余天数(months[month]-day),若差值小于零,则月份不变,日期(day)加上累加天数(days)即所求日期;若插值大于零,则月份(month)加一,用差值减去该月份天数,不断循环,直到差值小于零跳出循环,差值加上当前月份天数即为所求日期。需要注意的是,循环过程中月份可能会大于12,此时年份(year)需要加一,并且月份重置为1;年份变化时,还需要再次判断是否为闰年,若为闰年二月份天数改为29,否则改为28(如果没有改为28,当年份为闰年且加上若干天后变为平年时,在进入循环之前二月份天数被改为29,在while循环体内判断为平年,此时二月份天数仍为29,是错误的)。

复制代码
#include <stdio.h>

int main()
{
    int m = 0;
    scanf("%d\n",&m);
    int year = 0,month = 0,day = 0,days = 0;
    int months[13] = {0,31,28,31,30,31,30,31,31,30,31,30,31};
    while(scanf("%d %d %d %d\n",&year,&month,&day,&days) != EOF)
    {
        if((year % 400 == 0) || ((year % 4 == 0) && (year % 100 != 0)))
            months[2] = 29;
        days -= months[month] - day;
        while(days > 0)
        {
            month++;
            if(month > 12)
            {
                year++;
                month = 1;
            }
            if((year % 400 == 0) || ((year % 4 == 0) && (year % 100 != 0)))
            {
                months[2] = 29;
            }
            else
            {
                months[2] = 28;
            }
            days -= months[month];
        }
        day = months[month] + days;
        
        printf("%d-%02d-%02d\n",year,month,day);
    }
    return 0;
}

另一种思路:通过给定的年、月、日算出这一天是该年的第几天,然后将该天数加上给定的数值,反向求解,得出年、月、日。

相关推荐
C语言小火车3 小时前
野指针:C/C++内存管理的“幽灵陷阱”与系统化规避策略
c语言·c++·学习·指针
凤年徐3 小时前
【数据结构】时间复杂度和空间复杂度
c语言·数据结构·c++·笔记·算法
鑫宇吖3 小时前
Polyspace作为MISRA-C合规性检查工具,其检查规则会根据目标C语言标准(C90或C99)动态调整限值要求。
c语言·嵌入式·c99·c90·polyspace·misra-c合规性检查
钮钴禄·爱因斯晨4 小时前
C语言 | 函数核心机制深度解构:从底层架构到工程化实践
c语言·开发语言·数据结构
爱学习的小邓同学5 小时前
数据结构 --- 队列
c语言·数据结构
啟明起鸣11 小时前
【网络编程】简易的 p2p 模型,实现两台虚拟机之间的简单点对点通信,并以小见大观察 TCP 协议的具体运行
c语言·网络·tcp/ip·p2p
秋说16 小时前
【PTA数据结构 | C语言版】线性表循环右移
c语言·数据结构·算法
芯岭技术17 小时前
MS32C001-C单片机,32位ARM M0+内核,宽电压、低功耗、小封装。
c语言·arm开发·单片机
minji...19 小时前
数据结构 算法复杂度(1)
c语言·开发语言·数据结构·算法
秋说20 小时前
【PTA数据结构 | C语言版】在顺序表 list 的第 i 个位置上插入元素 x
c语言·数据结构·list