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

题目描述:

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

输入格式

输入包含多组测试数据。

每组数据占两行,分别表示两个日期,形式为 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 小时前
[特殊字符] 第40课:二叉树最大深度
数据结构·算法·数据库架构·图论·bfs·二叉树最大深度
沉鱼.441 小时前
第十二届题目
java·前端·算法
大熊背2 小时前
ISP Pipeline中Lv实现方式探究之三--lv计算定点实现
数据结构·算法·自动曝光·lv·isppipeline
初夏睡觉2 小时前
c++1.3(变量与常量,简单数学运算详解),草稿公放
开发语言·c++
西岸行者3 小时前
BF信号是如何多路合一的
算法
阿拉斯攀登3 小时前
从入门到实战:CMake 与 Android JNI/NDK 开发全解析
android·linux·c++·yolo·cmake
大熊背3 小时前
ISP Pipeline中Lv实现方式探究之一
算法·自动白平衡·自动曝光
罗西的思考4 小时前
【OpenClaw】通过 Nanobot 源码学习架构---(5)Context
人工智能·算法·机器学习
Liudef064 小时前
后量子密码学(PQC)深度解析:算法原理、标准进展与软件开发行业的影响
算法·密码学·量子计算
OYpBNTQXi6 小时前
SEAL全同态加密CKKS方案入门详解
算法·机器学习·同态加密