博客
关于我
(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学习总结(71)——数据库介绍(MySQL安装 体系结构、基本管理)再回顾
    查看>>
    Mysql学习总结(72)——MySQL 开发者开发,设计规范再总结
    查看>>
    Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
    查看>>
    Mysql学习总结(74)——慢SQL!压垮团队的最后一根稻草!
    查看>>
    Mysql学习总结(75)——并发量大、数据量大的互联网业务数据库设计军规
    查看>>
    Mysql学习总结(76)——MySQL执行计划(explain)结果含义总结
    查看>>
    Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
    查看>>
    Mysql学习总结(78)——MySQL各版本差异整理
    查看>>
    Mysql学习总结(79)——MySQL常用函数总结
    查看>>
    Mysql学习总结(7)——MySql索引原理与使用大全
    查看>>
    Mysql学习总结(80)——统计数据库的总记录数和库中各个表的数据量
    查看>>
    Mysql学习总结(81)——为什么MySQL不推荐使用uuid或者雪花id作为主键?
    查看>>
    Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
    查看>>
    Mysql学习总结(83)——常用的几种分布式锁:ZK分布式锁、Redis分布式锁、数据库分布式锁、基于JDK的分布式锁方案对比总结
    查看>>
    Mysql学习总结(84)—— Mysql的主从复制延迟问题总结
    查看>>
    Mysql学习总结(85)——开发人员最应该明白的数据库设计原则
    查看>>
    Mysql学习总结(8)——MySql基本查询、连接查询、子查询、正则表达查询讲解
    查看>>
    Mysql学习总结(9)——MySql视图原理讲解与使用大全
    查看>>
    Mysql学习笔记 - 在Centos7环境下离线安装Mysql
    查看>>
    MySQL学习笔记十七:复制特性
    查看>>