博客
关于我
求两个日期差值问题
阅读量: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 脏页 脏读 脏数据
查看>>
mysql 自增id和UUID做主键性能分析,及最优方案
查看>>
Mysql 自定义函数
查看>>
mysql 行转列 列转行
查看>>
Mysql 表分区
查看>>
mysql 表的操作
查看>>
mysql 视图,视图更新删除
查看>>
MySQL 触发器
查看>>
mysql 让所有IP访问数据库
查看>>
mysql 记录的增删改查
查看>>
MySQL 设置数据库的隔离级别
查看>>
MySQL 证明为什么用limit时,offset很大会影响性能
查看>>
Mysql 语句操作索引SQL语句
查看>>
MySQL 误操作后数据恢复(update,delete忘加where条件)
查看>>
MySQL 调优/优化的 101 个建议!
查看>>
mysql 转义字符用法_MySql 转义字符的使用说明
查看>>
mysql 输入密码秒退
查看>>
mysql 递归查找父节点_MySQL递归查询树状表的子节点、父节点具体实现
查看>>
mysql 通过查看mysql 配置参数、状态来优化你的mysql
查看>>