博客
关于我
(C++)设计一个程序能计算一个日期加上若干天后是什么日期
阅读量:754 次
发布时间:2019-03-23

本文共 1267 字,大约阅读时间需要 4 分钟。

对于给定的日期和累计天数,编写一个程序来计算加上这些天数后的新日期。使用二维数组存各个月份在平年和闰年的天数,并逐日处理每一天的累加。

问题分析

当给定一个日期和要累加的天数时,如何正确计算加上天数后的新日期。要处理闰年和平年对不同月份天数的影响,需要判断是否到下一个月,并决定是否进入下一个年份。

方法

  • 输入处理:读取输入的样例数量和每个样例的日期和天数。
  • 闰年判断:编写一个函数来判断给定年份是否为闰年。
  • 年度处理:创建一个二维数组,存储平年和闰年每个月的天数。
  • 逐日累加:逐个累加天数,处理每个月的天数,判断是否进入下一个月和年份。
  • 输出结果:格式化输出结果。
  • 解决代码

    #include 
    bool isLeap(int year) { return (year % 4 == 0 && year % 100 != 0) || (year % 400 == 0);}int main() { int n, yy, mm, dd, inc; scanf("%d", &n); for (; n > 0; --n) { scanf("%d %d %d %d", &yy, &mm, &dd, &inc); for (; inc > 0; --inc) { dd++; if (isLeap(yy)) { if (dd == monthDay[mm][1] + 1) { dd = 1; mm++; } } else { if (dd == monthDay[mm][0] + 1) { dd = 1; mm++; } } if (mm == 13) { mm = 1; yy++; } } printf("%d-%02d-%02d\n", yy, mm, dd); } return 0;}

    代码解释

  • 输入处理:读取输入的样例数n,然后逐行读取每个样例的年、月、日和累加天数。
  • 闰年判断:函数isLeap检查年份是否为闰年。
  • 月份天数数组monthDay数组存储平年和闰年各个月的天数。
  • 逐日累加:用于处理累加天数的循环,逐个加天数,检查是否进入下一个月,并调整月份和年份。
  • 结果输出:根据调整后的月份和年份,格式化输出结果。
  • 以上代码通过逐步的处理和优化,确保正确处理各种情况,包括闰年和平年月份的天数变化,以及跨年和跨月的情况,从而输出正确的新日期。

    转载地址:http://fhizk.baihongyu.com/

    你可能感兴趣的文章
    mysql执行计划怎么看
    查看>>
    MySQL执行计划解读
    查看>>
    mysql执行顺序与索引算法
    查看>>
    mysql批量update优化_Mysql中,21个写SQL的好习惯,你值得拥有呀
    查看>>
    mysql批量update操作时出现锁表
    查看>>
    MYSQL批量UPDATE的两种方式
    查看>>
    mysql批量修改字段名(列名)
    查看>>
    MySQL批量插入数据遇到错误1213的解决方法
    查看>>
    mysql技能梳理
    查看>>
    MySQL报Got an error reading communication packets错
    查看>>
    Mysql报错Can‘t create/write to file ‘/tmp/#sql_3a8_0.MYD‘ (Errcode: 28 - No space left on device)
    查看>>
    MySql报错Deadlock found when trying to get lock; try restarting transaction 的问题解决
    查看>>
    MySQL报错ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘
    查看>>
    Mysql报错Packet for query is too large问题解决
    查看>>
    mysql报错级别_更改MySQL日志错误级别记录非法登陆(Access denied)
    查看>>
    Mysql报错:too many connections
    查看>>
    MySQL报错:无法启动MySQL服务
    查看>>
    mysql授权用户,创建用户名密码,授权单个数据库,授权多个数据库
    查看>>
    mysql排序查询
    查看>>
    MySQL排序的艺术:你真的懂 Order By吗?
    查看>>