【两日期之间天数】c++,计算两日期之间的天数,蓝桥杯2023年A组真题

计算两个日期之间间隔多少天

输入开始日期和结束日期:
日期应以yyyy-mm-dd格式输入,使用年份的四位数,例如2001-05-21。

代码一:时间复杂度是o(n),这里的n是年数

#include <cstdio>
#include <cstring>
#include <iostream>

using namespace std;

const static int days[2][12] = {
    {31,28,31,30,31,30,31,31,30,31,30,31}, //平年
    {31,29,31,30,31,30,31,31,30,31,30,31},   //闰年
};
string s1,s2;

bool isRunYear(int year)
{
    if(year % 4 == 0 && year % 100 != 0 || year % 400 == 0)
        return true;
    else
        return false;
}
int date_date(string s1,string s2)
{
    string start = s1 < s2 ? s1 : s2;
    string end = s2 > s1 ? s2 : s1;
    
    int startYear,startMonth,startDay;
    int endYear,endMonth,endDay;
    
    sscanf(start.c_str(),"%d-%d-%d",&startYear,&startMonth,&startDay);
    sscanf(end.c_str(),"%d-%d-%d",&endYear,&endMonth,&endDay);
    
    int day = 0;
    
    for(int y = 1;y < startYear;y++)
        day -= isRunYear(y) ? 366 : 365;
    
    for(int y = 1;y < endYear;y++)
        day += isRunYear(y) ? 366 : 365;
    
    int gap = isRunYear(startYear);
    for(int m = 1;m < startMonth;m++)
        day -= days[gap][m-1];
    
    gap = isRunYear(endYear);
    for(int m = 1;m < endMonth;m++)
        day += days[gap][m-1];
        
    day += endDay - startDay;
    
    if(day < 0) day = 0;
    return day;
}
int main()
{
    cin >> s1 >> s2;   
    cout << date_date(s1,s2) << endl;
    
    return 0;
}

代码二:虽然说时间复杂度还是o(n),n是年份,或者说是o(max(n,m)),m是月份,因为很小,所以前面没算,这里还是看成o(n),虽然说还是o(n)但是性能要比上面的算法好很多,因为这个算法是计算两个年份之间的天数,不需要从0001年开始计算总天数。

#include <cstdio>
#include <cstring>
#include <iostream>

using namespace std;

const static int days[2][12] = {
    {31,28,31,30,31,30,31,31,30,31,30,31}, //平年
    {31,29,31,30,31,30,31,31,30,31,30,31},   //闰年
};
string s1,s2;

bool isRunYear(int year)
{
    if(year % 4 == 0 && year % 100 != 0 || year % 400 == 0)
        return true;
    else
        return false;
}
int date_date(string s1,string s2)
{
    string start = s1 < s2 ? s1 : s2;
    string end = s2 > s1 ? s2 : s1;
    
    int startYear,startMonth,startDay;
    int endYear,endMonth,endDay;
    
    sscanf(start.c_str(),"%d-%d-%d",&startYear,&startMonth,&startDay);
    sscanf(end.c_str(),"%d-%d-%d",&endYear,&endMonth,&endDay);
    
    int day = 0;
    
    if(startYear != endYear)
    {
        int gap = isRunYear(startYear);
        for(int m = startMonth;m <= 12;m++)
            day += days[gap][m-1] - startDay + 1,startDay = 1;
    }
    
    for(int y = startYear + 1;y < endYear;y++)
        day += isRunYear(y) ? 366 : 365;
    
    int gap = isRunYear(endYear);
    for(int m = 1;m < endMonth;m++)
        day += days[gap][m-1];
    day += endDay;
    
    return day - 1;
}
int main()
{
    cin >> s1 >> s2;   
    cout << date_date(s1,s2) << endl;
    
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值