cbm计算方式:C++编程:输入1900年至3000年间的任意两个日期(年月日),计算它们之间的天数并输出.

来源:百度文库 编辑:杭州交通信息网 时间:2024/05/02 04:30:00
判断合法性并提示...

肯定只能说伪码,代码要自己写
假设为Y1 M1 D1, Y2 M2 D2
(0) 基本准备
计算好每个月一号离1.1号有多少天放在一个数组里面(按不是闰年算),以后要用到;
int days[]= {31,31+28,31+28+31....};
(1)年月合法性检查(开始日期和结束日期)
a. 年份 在1900到3000
b. 月份 在1到12
(2)取得两个日期中当月的最大天数
比如1900.1.11 ~ 1991.2.25 则为Day_Max_Start= 31和Day_Max_End = 28
(3)判断日是否有效D1 <=Day_Max_Start而且D2<=Day_Max_End才有效
(4)计算1900.1.1年到1991.1.1有Sum天
(5)
Sum = Sum + days[M2] + D2 - (days[M1]+D1);
(6)前后闰年的判断
if { Y1 == 闰年 && 是在2.29号以后(包括2.29号)}
Sum = Sum -1;
if { Y1 == 闰年 && 是在2.29号以后(包括2.29号)}
Sum = Sum + 1;

自己在检查检查,比如
1900.1.1到1900.1.2是要算成1天还是两天.这也是个问题.