美文网首页
2018-09-07

2018-09-07

作者: WA馒头来了 | 来源:发表于2018-09-07 19:37 被阅读0次

题目如下:
输入:
输入时间,格式为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;
}

图示分析
`

相关文章

网友评论

      本文标题:2018-09-07

      本文链接:https://www.haomeiwen.com/subject/ezfhgftx.html