蓝桥杯每日一题:日期差值(日期问题)

题目描述:

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

输入格式

输入包含多组测试数据。

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

输出格式

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

数据范围

年份范围 1,9999,

保证输入日期合法。

测试数据的组数不超过 100。

输入样例:
复制代码
20110412
20110422
输出样例:
复制代码
11

解题思路:

输入两个日期,将两个日期全部转换为天,对于闰年且和二月再进行特判。

最后结果是两日期差值绝对值+1

由于是 多组测试数据知道具体组数输入的时候需要while(~scanf());

参考代码:

cpp 复制代码
#include <iostream>
#include <cstring>
#include <algorithm>

using namespace std;

int days[]{
    0,31,28,31,30,31,30,31,31,30,31,30,31
};

int leap(int y)
{
  if(y%400==0 || y%4==0 && y % 100) return 1;
  return 0;
}

int get_month(int y,int m)
{
    if(m==2) return 28+leap(y);
    return days[m];
}

int get_data(int year,int month,int day)
{
  int data = 0;
  for(int i=1;i<year;i++) data += 365 + leap(i);
  for(int i=1;i<month;i++) data += get_month(year,i);

  return  data += day;
}

int main()
{
    int y1,m1,d1,y2,m2,d2;
    while(~scanf("%04d%02d%02d\n%04d%02d%02d",&y1,&m1,&d1,&y2,&m2,&d2))
    {
        cout<<abs(get_data(y1,m1,d1) - get_data(y2,m2,d2)) + 1<<endl;
    }
    
    return 0;
}
相关推荐
菜菜的顾清寒1 分钟前
力扣HOT100(46)将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
zincsweet2 分钟前
System V 共享内存:原理剖析、代码架构分析与双端通信实战
linux·c++
随意起个昵称8 小时前
区间dp-基础题目1(石子合并)
算法·动态规划
吞下星星的少年·-·8 小时前
线段树模板
算法
wunaiqiezixin9 小时前
如何在C++中创建和管理线程
c++
段一凡-华北理工大学9 小时前
2026 高炉炼铁智能化技术全景与演进路径~系列文章11:演进路径与行业未来
大数据·网络·人工智能·算法·工业智能体·高炉炼铁智能化
雪度娃娃9 小时前
转向现代C++——在意为改写的函数添加 override
开发语言·c++
王老师青少年编程9 小时前
csp信奥赛C++高频考点专项训练之前缀和&差分 --【一维差分】:[NOIP 2018 提高组] 铺设道路
c++·前缀和·差分·csp·高频考点·信奥赛·铺设道路
叶小鸡9 小时前
小鸡玩算法-力扣HOT100-多维动态规划
算法·leetcode·动态规划
星马梦缘9 小时前
aaaaa
数据结构·c++·算法