计算两个日期之间的天数

题目描述

给定两个日期,计算相差的天数。比如2010-1-1和2010-1-3相差2天。

输入描述

共两行: 

第一行包含三个整数startYear,startMonth,startDay,分别是起始年、月、日。 

第二行包含三个整数endYear,endMonth,endDay,分别是结束年、月、日。 相邻两个整数之间用单个空格隔开。 年份范围在1~3000。保证日期正确且结束日期不早于起始日期。

输出描述

输出一个整数,即是两个日期相差的天数。

样例

输入

2008 1 1
2009 1 1

输出

366

提示

闰年被定义为能被4整除的年份,但是能被100整除而不能被400整除的年是例外,它们不是闰年。闰年的2月份有29天。

正确代码:

        #include<iostream>
using namespace std;
int f[15]={0,31,20,31,30,31,30,31,31,30,31,30,31};
int main(){
    int y,m,d,y1,m1,d1;
    int sum=0;
    cin>>y>>m>>d>>y1>>m1>>d1;
    if(y==y1&&m==m1){
        cout<<d1-d;
    }
    else if(y==y1&&m1!=m){
        if(y%100!=0&&y%4==0||y%400==0){
            f[2]=29;
        }
        else{
            f[2]=28;
        }
        for(int i=m;i<=m1-1;i++){
            sum+=f[i];
        }
        sum-=d;
        sum+=d1;
        cout<<sum;
    }
    else{
        for(int i=y+1;i<=y1-1;i++){
            if(i%100!=0&&i%4==0||i%400==0){
                sum+=366;
            }
            else{
                sum+=365;
            }
        }
        if(y%100!=0&&y%4==0||y%400==0){
            f[2]=29;
        }
        else{
            f[2]=28;
        }
        for(int i=m;i<=12;i++){
            sum+=f[i];
        }
        sum-=d;
        if(y1%100!=0&&y1%4==0||y1%400==0){
            f[2]=29;
        }
        else{
            f[2]=28;
        }
        for(int i=1;i<=m1-1;i++){
            sum+=f[i];
        }
        sum+=d1;
        cout<<sum;
    }
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值