博客
关于我
(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中出现Unit mysql.service could not be found 的解决方法
    查看>>
    mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
    查看>>
    Mysql中各类锁的机制图文详细解析(全)
    查看>>
    MySQL中地理位置数据扩展geometry的使用心得
    查看>>
    Mysql中存储引擎简介、修改、查询、选择
    查看>>
    Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
    查看>>
    mysql中实现rownum,对结果进行排序
    查看>>
    mysql中对于数据库的基本操作
    查看>>
    Mysql中常用函数的使用示例
    查看>>
    MySql中怎样使用case-when实现判断查询结果返回
    查看>>
    Mysql中怎样使用update更新某列的数据减去指定值
    查看>>
    Mysql中怎样设置指定ip远程访问连接
    查看>>
    mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
    查看>>
    Mysql中文乱码问题完美解决方案
    查看>>
    mysql中的 +号 和 CONCAT(str1,str2,...)
    查看>>
    Mysql中的 IFNULL 函数的详解
    查看>>
    mysql中的collate关键字是什么意思?
    查看>>
    MySql中的concat()相关函数
    查看>>
    mysql中的concat函数,concat_ws函数,concat_group函数之间的区别
    查看>>
    MySQL中的count函数
    查看>>