游客 Signup | Login
中文 | En

3909 - 活了多少天

      话说,小A和小B天天干架,今天小A和小B又干架了,他们俩干架有点特别,他们说出自己知道的人的名字,看看他们谁活的时间长,而且要计算出谁活的天数长,可是小A和小B都不会算他们活了多少天,只知道他们出生日期和死亡日期,聪明的ACM的你能帮他们写个高大上的程序给他们算算么?

Input

输入数据有多组,每组输入有两行,每行有三个数字,依次是年月日,中间用空格隔开,第一行是出生日期,第二行是死亡日期,输入数据都在int 范围内, 而且他出生年份一定小于去世年份。

Output

输出数据占一行,输出出生日期到死亡日期的天数。

Examples

Input

1606 2 24
1657 1 14

Output

18587

Solution C

#include<stdio.h>
int main()
{
    //freopen("111.txt","r",stdin);
    //freopen("111out.txt","w",stdout);
    int a[13] = {0, 31, 28, 31,30,31,30,31,31,30,31,30, 31};
    int year1, month1, day1, year2, month2, day2, i, sum;
    while(scanf("%d%d%d%d%d%d",&year1,&month1,&day1,&year2,&month2,&day2) != EOF)
    {
        sum = a[month1] - day1;
        for(i = month1 + 1; i <= 12; i++)
        {
            if(i == 2 && ((year1 % 4 == 0 && year1 % 100 != 0) || (year1 % 400 == 0)))
            {
                sum += 29;
                continue;
            }
            sum += a[i];
        }
        for(i = year1 + 1; i < year2; i++)
        {
            if((i % 4 == 0 && i % 100 != 0) || i % 400 == 0)
                sum += 366;
            else
                sum += 365;
        }
        sum += day2;
        for(i = 0; i < month2; i++)
        {
            if(i == 2 && ((year2 % 4 == 0 && year2 % 100 != 0) || (year2 % 400 == 0)))
            {
                sum += 29;
                continue;
            }
            sum += a[i];
        }
        printf("%d\n",sum);
    }
    return 0;
}

Solution C++

#include<iostream>
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<queue>
#include<math.h>
#define M(i,n,m) for(int i = n;i < m;i ++)
#define L(i,n,m) for(int i = n;i >= m;i --)
#define N(n,m) memset(n,m,sizeof(n));
const int MAX = 10010;

using namespace std;

int aa[13] = {0,31,28,31,30,31,30,31,31,30,31,30,31};

int is(int i)
{
    if((i%4 == 0 && i % 100 != 0)||(i % 400 == 0))
        return 1;
    return 0;
}

int main()
{
    int a,b,c,x,y,z;
    while(~scanf("%d%d%d%d%d%d",&a,&b,&c,&x,&y,&z))
    {
        int sum;
        sum = (x - a) * 365;
        for(int i = a; i < x; i ++)
            if(is(i))
                ++ sum;
        int t = c;
        for(int i = 1; i < b; i ++)
            t += aa[i];
        if(is(a) && b > 2)
            t ++;
        sum -= t;
        t = z;
        for(int i = 1; i < y; i ++)
            t += aa[i];
        if(is(x) && y > 2)
            t ++;
        sum += t;
        printf("%d\n",sum);
    }
    return 0;
}


Time Limit 1 second
Memory Limit 128 MB
Discuss Stats
上一题 下一题