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

题目描述:

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

输入格式

输入包含多组测试数据。

每组数据占两行,分别表示两个日期,形式为 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;
}
相关推荐
xieliyu.1 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
一条小锦吕*2 小时前
基于Spring Boot + 数据可视化 + 协同过滤算法的推荐系统设计与实现(源码+论文+部署全讲解)
spring boot·算法·信息可视化
如竟没有火炬3 小时前
最大矩阵——单调栈
数据结构·python·线性代数·算法·leetcode·矩阵
8Qi84 小时前
LeetCode 1143 & 718:最长公共子序列 / 最长重复子数组
算法·leetcode·职场和发展·动态规划
绿算技术4 小时前
万卡推理集群存储选型分析:从核心架构到应用视角
大数据·科技·算法·架构
Qt程序员5 小时前
Linux RCU 原理与应用
linux·c++·内核·linux内核·rcu
想吃火锅10055 小时前
【leetcode】1.两数之和js版
javascript·算法·leetcode
qeen875 小时前
【C++】类与对象之类的默认成员函数(二)
android·c语言·开发语言·c++·笔记·学习
net3m336 小时前
一阶软件低通滤波器算法
人工智能·算法