博客
关于我
求两个日期差值问题
阅读量:328 次
发布时间:2019-03-04

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

题目描述

给定两个日期,求这两个日期之间的天数,如果两个日期连续规定他们之间的相差天数为两天。

输入格式:

输入两个日期,格式为NNNNYYRR

输出格式:

输出一行,即日期差值。

输入样例:

20150202

20160202

输出样例:

366

分析:

一个简单的思路,先确定两个日期的大小,取出年月日,小日期向大日期递增,每次天数加一,总差值加一。若天数超过了本月的最大天数,则月份加一,如果当前月份达到了十二,则年份加一,同时判断闰年和平年,月份置一,天数置一。

#include 
using namespace std;void Compare(int &minDate, int &maxDate) { if (minDate > maxDate) { int temp = minDate; minDate = maxDate; maxDate = temp; }}bool leapYear(int year) { if ((year % 4 == 0 && year % 100 != 0) || (year % 400 == 0)) return true; else return false;}void setMonth(int year, int month[]) { if (leapYear(year)) month[2] = 29; else month[2] = 28;}int dateDifference(int month[], int year1, int year2, int month1, int month2, int day1, int day2) { int sumDays = 1; while (year1 != year2 || month1 != month2 || day1 != day2) { if (day2 <= month[month2]) { day2++; sumDays++; } else { if (month2 < 12) { month2++; day2 = 1; } else { year2++; setMonth(year2, month); month2 = 1; day2 = 1; } } } return sumDays;}int main() { int minDate; int maxDate; cin >> minDate >> maxDate; int sumDays; int month[13]; month[1] = 31; month[3] = 31; month[4] = 30; month[5] = 31; month[6] = 30; month[7] = 31; month[8] = 31; month[9] = 30; month[10] = 31; month[11] = 30; month[12] = 31; Compare(minDate, maxDate); int maxYear = maxDate / 10000; int minYear = minDate / 10000; int month1 = (maxDate / 100) % 100; int month2 = (minDate / 100) % 100; int day1 = maxDate % 100; int day2 = minDate % 100; setMonth(minYear, month); sumDays = dateDifference(month, maxYear, minYear, month1, month2, day1, day2); cout << sumDays << endl; return 0;}

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

你可能感兴趣的文章
mysql 存储过程每隔一段时间执行一次
查看>>
mysql 存在update不存在insert
查看>>
Mysql 学习总结(86)—— Mysql 的 JSON 数据类型正确使用姿势
查看>>
Mysql 学习总结(87)—— Mysql 执行计划(Explain)再总结
查看>>
Mysql 学习总结(88)—— Mysql 官方为什么不推荐用雪花 id 和 uuid 做 MySQL 主键
查看>>
Mysql 学习总结(89)—— Mysql 库表容量统计
查看>>
mysql 实现主从复制/主从同步
查看>>
mysql 审核_审核MySQL数据库上的登录
查看>>
mysql 导入 sql 文件时 ERROR 1046 (3D000) no database selected 错误的解决
查看>>
mysql 导入导出大文件
查看>>
MySQL 导出数据
查看>>
mysql 将null转代为0
查看>>
mysql 常用
查看>>
MySQL 常用列类型
查看>>
mysql 常用命令
查看>>
Mysql 常见ALTER TABLE操作
查看>>
MySQL 常见的 9 种优化方法
查看>>
MySQL 常见的开放性问题
查看>>
Mysql 常见错误
查看>>
mysql 常见问题
查看>>