博客
关于我
(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 多个表求多个count
    查看>>
    mysql 多字段删除重复数据,保留最小id数据
    查看>>
    MySQL 多表联合查询:UNION 和 JOIN 分析
    查看>>
    MySQL 大数据量快速插入方法和语句优化
    查看>>
    mysql 如何给SQL添加索引
    查看>>
    mysql 字段区分大小写
    查看>>
    mysql 字段合并问题(group_concat)
    查看>>
    mysql 字段类型类型
    查看>>
    MySQL 字符串截取函数,字段截取,字符串截取
    查看>>
    MySQL 存储引擎
    查看>>
    mysql 存储过程 注入_mysql 视图 事务 存储过程 SQL注入
    查看>>
    MySQL 存储过程参数:in、out、inout
    查看>>
    mysql 存储过程每隔一段时间执行一次
    查看>>
    mysql 存在update不存在insert
    查看>>
    Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
    查看>>
    Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
    查看>>
    Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
    查看>>
    Mysql 学习总结(89)—— Mysql 库表容量统计
    查看>>
    mysql 实现主从复制/主从同步
    查看>>