题目如下:
输入:
输入时间,格式为2018-09-07当只输入一个时,需要系统自动生成当前时间,当输入两个时间时,只需要进行计算即可
输出;
要求计算两个时间的差值 ,中间相隔多少周。
样例如下(以输入两个为例子):
输入:
2018-09-03
2018-09-04
输出;
中间共相隔0周零1天
分析如下:
1,需要一个程序来输出系统时间
2,需要进行闰年的判定,另外需要数组保存每月的天数
代码如下:
#include<iostream>
#include<stdio.h>
#include<time.h>
using namespace std;
struct stu{
int year;
int month;
int day;
}y_m_d[2];
char c;
/* 返回绝对值 */
//即是从y1年m1月d1日到y1年m1月d2日
int abs(int a,int b)
{
if(a>=b)
return (a-b);
else
return (b-a);
}
/* 判断是否为闰年:是,返回 1 ; 不是, 返回 0 . */
int IsLeap(int year)
{
if(((year%4==0)&&(year%100!=0))||year%400==0)
return 1;
else
return 0;
}
/* 判断某个日期从年初(y年1月1日)到该天(y年m月d日)的天数 */
int Days(int y,int m,int d)
{
int days[]={0,31,28,31,30,31,30,31,31,30,31,30,31};
int i;
int sum = 0 ; /* 计算天数 */
if(IsLeap(y)) /* 如果为闰年,2月有 29 天 */
days[2] = 29 ;
for(i=0;i<m;i++)
sum = sum +days[i] ;
sum = sum + d - 1 ;
return sum;
}
/*
判断两个日期之间的天数.
日期一:年 y1,月 m1,日 d1;
日期一:年 y2,月 m2,日 d2;
*/
int DiffDays(int y1,int m1,int d1,int y2,int m2,int d2)
{
int s1,s2; /* 计算两个日期从年初到该日期的天数 */
int count; /* 计算两个年份之间的差值 */
int sum=0; /* */
int t,t1,t2;
if(y1==y2)
{
s1 = Days(y1,m1,d1);
s2 = Days(y2,m2,d2);
return abs(s1,s2);
}
else if(y1>y2)
{
count = y1 - y2 ;
if(count == 1)
{
t1 = Days(y1,m1,d1);
t2 = Days(y2,12,31) - Days(y2,m2,d2);
return (t1+t2+count);
}
else
{
for(t = y2+1;t<y1;t++)
sum = sum + Days(t,12,31);
cout<<sum<<endl;
t2 = Days(y2,12,31) - Days(y2,m2,d2);
t1 = Days(y1,m1,d1);
return (sum+t1+t2+count);
}
}
else
{
count = y2 - y1 ;
if(count == 1)
{
t2 = Days(y2,m2,d2);
t1 = Days(y1,12,31) - Days(y1,m1,d1);
return (t1+t2+count);
}
else
{
for(t = y1+1;t<y2;t++)
sum = sum + Days(t,12,31);
t2 = Days(y2,m2,d2);
t1 = Days(y1,12,31) - Days(y1,m1,d1);
return (sum+t1+t2+count);
}
}
}
int main()
{
int i;
int j;
int k;
printf("请输入i的值,以方便确定是否采用系统时间\n");
cin>>i;
if(i==1)
{
// time_t t;
// struct tm * lt;
// time (&t);//获取Unix时间戳。
// lt = localtime (&t);//转为时间结构。
// printf ( "%d/%d/%d %d:%d:%d\n",lt->tm_year+1900, lt->tm_mon+1, lt->tm_mday, lt->tm_hour, lt->tm_min, lt->tm_sec);//输出结果
time_t t;
struct tm * lt;
time (&t);//获取Unix时间戳。
lt = localtime (&t);//转为时间结构。
y_m_d[0].year=lt->tm_year+1900;
y_m_d[0].month=lt->tm_mon+1;
y_m_d[0].day=lt->tm_mday;
cin>>y_m_d[1].year>>c>>y_m_d[1].month>>c>>y_m_d[1].day;
for(j=0;j<2;j++)
{
cout<<y_m_d[j].year<<c<<y_m_d[j].month<<c<<y_m_d[j].day<<endl;
}
k=DiffDays(y_m_d[0].year,y_m_d[0].month,y_m_d[0].day,y_m_d[1].year,y_m_d[1].month,y_m_d[1].day);
cout<<k<<endl;
cout<<y_m_d[0].year<<c<<y_m_d[0].month<<c<<y_m_d[0].day<<"距离"<<y_m_d[1].year<<c<<y_m_d[1].month<<y_m_d[1].day<< <<k/7<<"周零"<<k%7<<"天"<<endl;
}
else if(i==2)
{
for(j=0;j<2;j++)
{
cin>>y_m_d[j].year>>c>>y_m_d[j].month>>c>>y_m_d[j].day;
}
for(j=0;j<2;j++)
{
cout<<y_m_d[j].year<<c<<y_m_d[j].month<<c<<y_m_d[j].day<<endl;
}
k=DiffDays(y_m_d[0].year,y_m_d[0].month,y_m_d[0].day,y_m_d[1].year,y_m_d[1].month,y_m_d[1].day);
cout<<k<<endl;
cout<<y_m_d[0].year<<c<<y_m_d[0].month<<c<<y_m_d[0].day<<"距离"<<y_m_d[1].year<<c<<y_m_d[1].month<<y_m_d[1].day<< <<k/7<<"周零"<<k%7<<"天"<<endl;
}
return 0;
}
图示分析
`
网友评论