Codeup 1000001928: 日期差值

                                 1928: 日期差值

时间限制: 1 Sec  内存限制: 32 MB
 

题目描述

有两个日期,求两个日期之间的天数,如果两个日期是连续的我们规定他们之间的天数为两天。

输入

有多组数据,每组数据有两行,分别表示两个日期,形式为YYYYMMDD

输出

每组数据输出一行,即日期差值

样例输入

20130101
20130105

样例输出

5
#include<stdio.h>
int month[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 isLeap(int year)
{
    return((year%4==0&&year%100!=0)||(year%400==0)); //判断是否为闰年,是则返回1,否返回0,刚好对应month[][]的列标0~1
}
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 count=1;
        while(!(y1==y2&&m1==m2&&d1==d2))         //第一个日期没有到达第二个日期前一直循环,#标注1     
        {
            count++;
            d1++;
            if(d1==(month[m1][isLeap(y1)]+1))
            {
                m1++;
                d1=1;
            }
            if(m1==13)
            {
                y1++;
                m1=1;
            }
        }
        printf("%d\n",count);
    }
    return 0;
}


#标注1:这种求日期差数的题目,最直接的思路是,另天数不断加1,直到第一个日期等于第二个日期为止,即可统计出答案

(1)天数加1后,判断是否等于当前月份的天数+1后的值,那么可以令月份加1,同时置天数为1号(变为下个月的一号)

(2)同理,对月份的处理也如此,月份m变为13,则令年份加1,置月份m为1。

(3)题目中描述日起连续算为2天,则计数值count初始化为1

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值