时间差值问题

题目描述: 
有两个日期,求两个日期之间的天数,如果 两个日期是连续的我们规定他们之间的天数为两天。 
输入: 
有多组数据,每组数据有两行,分别表示两个日期,形式为YYYYMMDD。 
输出: 
每组数据输出一行,即日期差值。 
样例输入: 
20110412 
20110422 
样例输出: 
11
方法一:统一到特定日期与一个原点时间(如0000年1月1日)的天数差

#include<cstdio>
#define RUN(x) x%100!=0&&x%4==0||x%400==0?1:0  //判断是否是闰年,
//                                               闰年结果为1,不是闰年结果是0

int dayofmonth[13][2]={      //每个月的天数,用上面RUN(x)来控制2月的天数
        0,0,
        31,31,
        28,29,
        31,31,
        30,30,
        31,31,
        30,30,
        31,31,
        31,31,
        30,30,
        31,31,
        30,30,
        31,31};

    struct Date      //日期,包括年,月,日和计算下一天
    {
        int day;
        int month;
        int year;
        void nextday()
        {
            day++;
            if(day>dayofmonth[month][RUN(year)])
            {
                day=1;
                month++;
                if(month>12)
                {
                    month=1;
                    year++;
                }
            }
        }
    };

    int buf[5001][13][32];    //buf矩阵保存0年1月1日一直到5000年12月31日每一天与0年1月1日的差
    int Abs(int x)     //求差的绝对值
    {
        return x<0?-x:x;
    }

    int main()
    {
        Date tmp;
        int cnt=0;
        tmp.year=0;tmp.month=1;tmp.day=1;
        while(tmp.year<=5000)
        {
            buf[tmp.year][tmp.month][tmp.day]=cnt;//计算0年1月1日一直到5000年12月31日每一天与0年1月1日的差
            tmp.nextday();
            cnt++;
        }
        int y1,m1,d1,y2,m2,d2;
        while(scanf("%4d%2d%2d",&y1,&m1,&d1)!=EOF)
        {
            scanf("%4d%2d%2d",&y2,&m2,&d2);
            printf("%d\n",Abs(buf[y2][m2][d2]-buf[y1][m1][d1])+1);//利用矩阵buf取出和0年1月1日的差,做差取绝对值
        }                                                         //根据题目连续两天差为2,需要给绝对值+1
        return 0;
    }
--------------------- 
作者:landcruiser007 
来源:CSDN 
原文:https://blog.csdn.net/landcruiser007/article/details/79603699 
版权声明:本文为博主原创文章,转载请附上博文链接!

方法二:把一个日期不断加1天,直到一个日期等于第二个日期位置,即可统计出答案

#include<stdio.h>
#define isYeap(x) ((x%100!=0)&&(x%4==0)||(x%400==0))?1:0
int dayOfMonth[13][2]={
        0,0,
        31,31,
        28,29,
        31,31,
        30,30,
        31,31,
        30,30,
        31,31,
        31,31,
        30,30,
        31,31,
        30,30,
        31,31
};
int main(){
    int time1,y1,m1,d1;
    int time2,y2,m2,d2;
    while(scanf("%d%d",&time1,&time2)!=EOF){
        if(time1>time2){
            int temp=time1;
            time1=time2;
            time2=temp;
        }
        y1=time1/10000;m1=time1%10000/100;d1=time1%100;
        y2=time2/10000;m2=time2%10000/100;d2=time2%100;
        int ans=1;//记录结果
        while(y1<y2||m1<m2||d1<d2){
            d1++;
            if(d1==dayOfMonth[m1][isYeap(y1)]+1){//满当月天数
                m1++;
                d1=1;
            }
            if(m1==13){//满一年
                y1++;
                m1=1;
            }
            ans++;
        }
            printf("%d\n",ans);
    }
    return 0;

}

 

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值