算法09 日期相关模拟算法【C++实现】

这是《C++算法宝典》算法篇的第09节文章啦~

如果你之前没有太多C++基础,请点击👉专栏:C++语法入门,如果你C++语法基础已经炉火纯青,则可以进阶算法👉专栏:算法知识和数据结构👉专栏:数据结构啦

目录

❀前言

📕得到某年某月的天数

🧠普通闰年

🧠世纪闰年

📕得到某年某月的天数

📕判断日期的合法性

📕训练:第n天的日期

🧠第n天的日期参考代码

📕训练:日期距离

🧠日期距离参考代码


前言

无论是中小学编程竞赛还是大学生编程竞赛,日期模拟都是经常会出现的题目。

日期模拟经常会出现以下题型:

  • 得到某年某月的天数
  • 判断给定日期的合法性
  • 给定年份,求这一年第n天的日期
  • 给定年月日,求经过n天后的日期
  • 查找两个日期之间有多少个回文日期... ...

得到某年某月的天数

得到某年某月的天数问题经常会作为其他问题的模板来使用。

首先我们需要存储一年中所有月份相对应的天数

int day[] = {0,31,28,31,30,31,30,31,31,30,31,30,31}

其中day[1]表示一月份最多31天,2月份先赋值为28天,具体天数还需要检测年份是否是闰年,如果是闰年还需要+1天

闰年分为两种:

普通闰年

年份是4的倍数,但不是100的倍数,例如2004、2020年等

世纪闰年

是400的倍数,例如1900不是世纪闰年,2000是世纪闰年,即:

if(year % 4 == 0 && year % 100 != 0 || year % 400 == 0)是闰年;else不是;

得到某年某月的天数

当月份不是2月时,就返回指定当前月份初始天数

当月份是2月时,判断年份是否是闰年,当年份为闰年成立时,leap值为1,不成立时值为0,初始天数加上leap的值即为2月份天数

int days[] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};// 得到某年某月的天数int check(int y, int m){if(m != 2) return days[m];else{//特判 2 月int leap = (y % 4 == 0 && y % 100 != 0 || y % 400 == 0);return days[m] + leap;}}

判断日期的合法性

一般这样的题型会先给你一个格式,看是否符合这个格式,比如要满足20230701这样的格式才是合法的。

首先你需要分离出年份,再分离出月份,最后分离出日。

再分别判断年月日是否符合题意

if(m<1||m>12) 则月份不符合if(d<1||d>(指定月份的总天数)) 则日不符合

注:年份一般不需要检查,但也要视题意而定

训练:第n天的日期

给定一个年份y和一个整数d,问这一年的第d天是几月几日?注意闰年的2月有29天。满足下面条件之一的是闰年:

1、年份是4的整数倍,而且不是100的整数倍;

2、年份是400的整数倍。

【输入描述】输入的第一行包含一个整数y,表示年份,年份在1900到2015之间(包含1900和2015)。

输入的第二行包含一个整数d,d在1至365之间。

【输出描述】输出两行,每行一个整数,分别表示答案的月份和日期。

【样例输入1】

2015

80

【样例输出】

3

21

第n天的日期参考代码

#include <iostream>
using namespace std;
int day[13]={0,31,0,31,30,31,30,31,31,30,31,30,31};
bool check(int n)  //判断闰年
{if(n%400==0||(n%4==0&&n%100!=0)) return true;return false;
}
int main()
{int m,n;cin>>m>>n;if(check(m))  day[2]=29;else  day[2]=28;for(int j=1;j<=12;j++){n-=day[j];if(n<0){cout<<j<<endl<<day[j]+n;break;}if(n==0){cout<<j<<endl<<day[j];break;}}return 0;
}

训练:日期距离

 输入一个的日期,输出它和2014年5月17日相差有多少天?注意闰年的2月有29天。满足下面条件之一的是闰年:

1、年份是4的整数倍,而且不是100的整数倍;

2、年份是400的整数倍。

【输入描述】输入的第一行包含一个整数y,表示年份,年份在1到2014之间(包含1和2014)。

输入的第二行包含一个整数m,表示月份,m在1至12之间。

输入的第三行包含一个正整数d,表示日期,d在1至31之间。

【输出描述】输出两个日期之间相差的天数。

【输入样例】

1988

7

3

【输出样例】

9449

日期距离参考代码

#include <iostream>
using namespace std;
int day[13]={0,31,0,31,30,31,30,31,31,30,31,30,31};
bool check(int k)  //判断闰年
{if(k%400==0||(k%4==0&&k%100!=0))return true;return false;
}
int sum;//计算总天数
int main()
{int m,n,d;cin>>m>>n>>d;if(check(m))  day[2]=29;else  day[2]=28;for(int i=m+1;i<2014;i++)  //计算完整的年份天数{if(check(i))  sum+=366;else sum+=365;}if(m==2014){for(int i=n+1;i<5;i++) //计算完整的月份的天数sum+=day[i];if(n==5) sum+=17-d;else sum+=day[n]-d+17;}else{sum+=137; //2014.1.1~2014.5.17总天数for(int i=n+1;i<=12;i++)   //算上完整月份天数sum+=day[i];sum+=day[n]-d;   }cout<<sum<<endl;return 0;
}

从入门到算法,再到数据结构,查看全部文章请点击此处​​​​​icon-default.png?t=N7T8http://www.bigbigli.com/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/38474.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算斜率,判断斜率

#include <stdio.h> #include <stdlib.h> #include <math.h> #include <stdbool.h>// 定义常量 #define LOW_COOK_WINDOW_SIZE 20 // 滑动窗口大小&#xff0c;10个样本点&#xff08;10秒&#xff09; #define LOW_COOK_SLOPE…

Java代码生成器(开源版本)

一、在线地址 Java在线代码生成器&#xff1a;在线访问 二、页面截图 三、核心功能 支持Mybatis、MybatisPlus、Jpa代码生成使用 antlr4 解析SQL语句&#xff0c;保证了SQL解析的成功率支持自定义包名、作者名信息支持自定义方法名、接口地址支持自定义选择是否生成某个方法…

16-Python Pandas聚合函数

Python Pandas聚合函数 窗口函数可以与聚合函数一起使用&#xff0c;聚合函数指的是对一组数据求总和、最大值、最小值以及平均值的操作。 应用聚合函数 首先让我们创建一个 DataFrame 对象&#xff0c;然后对聚合函数进行应用。 import pandas as pd import numpy as np d…

SQL中的子查询和CTE(with ....as..)

第一次看到with as 这种类似于python中读文件的写法还是挺疑惑的&#xff0c;其实它是CTE&#xff0c;功能和子查询很类似但又有不同点&#xff0c;在实际应用场景中具有着独特作用。 子查询 子查询是在主查询中的嵌套查询&#xff0c;可以出现在SELECT、FROM、WHERE等子句中…

ai除安卓手机版APP软件一键操作自动渲染去擦消稀缺资源下载

安卓手机版&#xff1a;点击下载 苹果手机版&#xff1a;点击下载 电脑版&#xff08;支持Mac和Windows&#xff09;&#xff1a;点击下载 一款全新的AI除安卓手机版APP&#xff0c;一键操作&#xff0c;轻松实现自动渲染和去擦消效果&#xff0c;稀缺资源下载 1、一键操作&…

数学建模(1):期末大乱炖

1 概述&#xff01;&#xff01; 1.1 原型和模型 原型&#xff1a;客观存在的研究对象称为原型&#xff0c;也称为“系统”、“过程”。 机械系统、电力系统、化学反应过程、生产销售过程等都是原型&#xff1b; 研究原型的结构和原理&#xff0c; 从而进行优化、预测、评价…

Perl编程艺术:深入探索Tie机制的魔力

&#x1f31f; Perl编程艺术&#xff1a;深入探索Tie机制的魔力 在Perl的世界里&#xff0c;tie功能是一种极其强大的特性&#xff0c;它允许程序员将变量绑定到一个对象上&#xff0c;从而改变这个变量的默认行为。这种机制为变量提供了一种代理访问方式&#xff0c;使得变量…

Jedis、Lettuce、RedisTemplate连接中间件

jedis就像jdbc一样&#xff0c;用于两个端直接的连接。 1.创建Spring项目 这里不过多赘述... 2.导入连接工具jedis 在pom文件中导入jedis的依赖。 <dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version&…

结合数据索引结构看SQL的真实执行过程

引言 关于数据库设计与优化的前几篇文章中&#xff0c;我们提到了数据库设计优化应该遵守的指导原则、数据库底层的索引组织结构、数据库的核心功能组件以及SQL的解析、编译等。这些其实都是在为SQL的优化、执行的理解打基础。 今天这篇文章&#xff0c;我们以MySQL中InnoDB存…

vim卡死

有些时候使用vim的时候莫名其妙的会卡死&#xff0c;导致输入不了内容。查了一下资料发现&#xff0c;其实并不是vim卡死&#xff0c;而是在使用vim的工程中带入了许多Windows上的使用习惯&#xff0c;比如“Ctrl-s”保存等&#xff0c;这可能会与Linux平台的有些快捷键冲突。c…

Oracle PL / SQL 表 table

关系数据库允许您在数据库管理系统&#xff08;DBMS&#xff09;中存储多个表。 您可以使用计算机上的查询语言来操作表中的数据。 当前的查询语言是结构化查询语言&#xff08;SQL&#xff09;。 SQL是一组无关的命令&#xff0c;用于操作关系数据库管理系统&#xff08;RD…

CleanMyMacX2024免费且强大的mac电脑系统优化工具

如果你的Mac电脑出现了存储空间不足、运行缓慢、电池电量消耗过快等问题&#xff0c;那么CleanMyMacX这款软件或许能为你提供解决方案。作为一款强大的系统优化工具&#xff0c;它能够帮助用户清理垃圾文件、优化内存和电池使用&#xff0c;从而提升Mac的性能表现&#xff0c;让…

后端之路第三站(Mybatis)——XML文件操作sql

一、XML映射文件是啥 前面我们学过了在Mapper接口用注解的方式来操作sql语句 那么XML映射文件就另一种操作sql语句的方法 为什么还要有这么个玩意&#xff1f; 我简单说就是&#xff1a;如果有的sql特别复杂的话&#xff0c;比如需要【动态sql】的话&#xff0c;就得用到XM…

【Android面试八股文】Fragment的add和replace的区别,分别对Fragment的生命周期有什么影响?

文章目录 一、Fragment的add和replace的区别 ,分别对Fragment的生命周期有什么影响?1.1 `add` 方法1.2 `replace` 方法1.3 应用场景1.4 Fragment事务操作提交流程1.5 replace操作的本质是不是就是remove操作和add操作的组合?1.6 示例代码:将一个已经存在的 `FragmentA` 替换…

电脑开机之后,键盘鼠标需要重新插拔才能正常使用?

前言 小白平时修电脑修得多&#xff0c;总是会遇到各种各样的奇葩问题。这不&#xff0c;又有一位小伙伴来咨询&#xff1a;电脑开机之后&#xff0c;键盘鼠标都不能用&#xff0c;需要重新插拔一下才能正常使用。 啧啧啧&#xff0c;真的是很奇怪的问题&#xff0c;基本上没见…

分页缓存与下拉刷新的整合原理 - DoraPageDatabaseCacheRepository

何为分页缓存&#xff1f; 顾名思义&#xff0c;分页缓存就是边分页边缓存&#xff0c;分页通常使用下拉刷新控件实现&#xff0c;而缓存通常说的是指磁盘缓存&#xff0c;即保存到数据库中&#xff0c;数据库本身也是一个索引文件。 为什么缓存还要分页&#xff1f; 在很大…

SSH 无密登录配置流程

一、免密登录原理 非对称加密&#xff1a; 由于对称加密的存在弊端&#xff0c;就产生了非对称加密&#xff0c;非对称加密中有两个密钥&#xff1a;公钥和私钥。公钥由私钥产生&#xff0c;但却无法推算出私钥&#xff1b;公钥加密后的密文&#xff0c;只能通过对应的私钥来解…

光速入门 Tailwind CSS

文章目录 入门安装IDE 设置使用预编译器生产环境优化 基础概念分层指令tailwindlayerapplyconfig 函数theme()screen() 基础案例怎么设置属性任意值&#xff1f;hover 父元素时&#xff0c;怎么选中子元素添加样式&#xff1f;添加 animation 动画 配置主题 Tailwind CSS 中文网…

.so: file not recognized: file format not recognized

项目场景&#xff1a; 自Linux 4.8起&#xff0c;传统的GPIO sysfs接口被弃用。libgpiod操作gpio的方式感觉更加方便。 但是单板上好像没装这个工具&#xff0c;又到了熟悉的交叉编译环节&#xff08;痛苦&#xff09;。 问题描述 按照流程装完libgpiod&#xff0c;自信地去交…

安卓Gradle学习与应用:从入门到实践

引言 在Android开发的世界里&#xff0c;Gradle不仅仅是一个构建工具&#xff0c;它更是一种强大的自动化系统&#xff0c;能够帮助开发者高效地管理项目依赖、编译、测试、打包以及部署。本篇博客旨在深入探讨Gradle在Android开发中的应用&#xff0c;从基础概念到实战技巧&a…