数组编程实例
描述:给定两个日期,计算相差的天数。比如2010-1-1和2010-1-3相差两天。
输入:
共两行:
第一行包含三个整数startYear,startMonth,startDay,分别是起始年月、月、日。
第二行包含三个整数endYear,endMonth,endDay,分别是结束年、月、日。相邻两个整数之间用单个空格隔开。
年份范围在1~3000。保证日期正确且结束日期不早于起始日期。
输出:输出一个整数,即是两个日期相差的天数。
第一种:
#include<iostream>
using namespace std;
bool isrun(int year);//判断闰年
int main()
{
int months[13]={0,31,29,31,30,31,30,31,31,30,31,30,31};//月之天数
int y1,m1,d1,y2,m2,d2;
cin>>y1>>m1>>d1>>y2>>m2>>d2;
if(isrun(y1)) months[2]=29;
else months[2]=28;
int n=0;
while(y1!=y2 || m1!=m2 || d1!=d2)
{
n++;
if(m1==12 && d1==31)
{
y1++;
if(isrun(y1)) months[2]=29;
else months[2]=28;
m1=1;
d1=1;
}
else if(months[m1]==d1)
{
m1++;
d1=1;
}
else d1++;
}
cout<<n;
return 0;
}
bool isrun(int year)
{
if(year%4==0 && year %100!=0 || year%400==0)
return true;
else return false;
}
第二种(优化后,效率要高一点):
#include<iostream>
using namespace std;
bool isrun(int y);//判断闰年
int ds(int y,int m,int d);//计算日期距离同年的1月1日有多少天
int days[]={0,31,29,31,30,31,30,31,31,30,31,30,31};
int main()
{
int y1,m1,d1,y2,m2,d2;
cin>>y1>>m1>>d1>>y2>>m2>>d2;
int a=ds(y1,m1,d1);
int b=ds(y2,m2,d2);
int s=0;
for(int i=y1;i<y2;i++)
{
if(isrun(i)) s+=366;
}
cout<<s+b-a;
return 0;
}
bool isrun(int y)
{
if (y%4==0 && y%100!=0 || y%400==0)
return true;
else return false;
}
int ds(int y,int m ,int d)
{
int sum=0;
if (isrun(y)) days[2]=29;
else days[2]=28;
for(int i =1;i<m;i++)//按月累加天数
sum +=days[i];
return sum+d;
}