当前位置:网站首页>每日一练:关于日期的一系列
每日一练:关于日期的一系列
2022-07-05 17:17:00 【利刃Cc】
计算日期到天数转换

链接: 计算日期到天数转换
思路1:常规的思路是用while循环从这个月的一号循环到该天,但是其实还有很简单的思路,也就是下面的思路二,还有主要讲的也是思路二。
思路二:用一个数组存放每个月累加起来的天数,如第一个月是31天,第二个月是存放31+28=59天,以此类推,这样子存放是有好处的。
我们求这年到某一天的总天数就是这个月的前一个月,以及这个月以前所有天数累加起来的天数和加上该月的天数!但是别忘了判断这一年是否为闰年以及这一天是否超过了二月(因为还没过二月的话没必要加一天)
代码:
#include<iostream>
using namespace std;
int main()
{
int arr[13] = {
0,31,59,90,120,151,181,212,243,273,304,334,365};
int year, month, day;
cin >> year >> month >> day;
//让n赋值上从这年到这个月的上个月的总天数再加上现在的天数day
int n = arr[month - 1] + day;
//记得判断是否为闰年
if(month > 2 && (((year % 4 == 0) && (year % 100 != 0)) || (year % 400 == 0)))
n++;
cout << n;
return 0;
}
日期累加

链接: 日期累加
思路:因为这道题要求m个测试用例,所以要循环m遍。并用nowday记录当月最大天数,便于后面的判断。
然后用while子循环,将addday的天数累加到day和month上,然后addday–。
每次循环都判断一下当天是不是超过当月最大天数,以及该月是不是超过了12月。
代码:
#include<iostream>
using namespace std;
int main()
{
int arr[13] = {
0,31,28,31,30,31,30,31,31,30,31,30,31};
int m = 0;
cin >> m;
int year = 0, month = 1, day = 1, addday = 0;
//因为有多组测试用例,所以用m来循环
for(int i=0; i<m; i++)
{
cin >> year >> month >> day >> addday;
int nowday = arr[month];//用nowday记录当月最大天数
while(addday > 0)
{
day++;
if((month == 2) && ((year%4==0 && year%100!=0) || (year%400==0)))
{
nowday=29;
}
//判断天数是否大于当月最大天数
if(day > nowday)
{
day = 1;
month++;
//判断月数是否大于12
if(month > 12)
{
month=1;
year++;
}
nowday=arr[month];
}
addday--;
}
//把天和月按格式打印
if(day<10 && month<10)
cout<<year<<"-0"<<month<<"-0"<<day<<endl;
else if(day<10 && month>=10)
cout<<year<<'-'<<month<<"-0"<<day<<endl;
else if(day>=10 && month<10)
cout<<year<<"-0"<<month<<'-'<<day<<endl;
else
cout<<year<<'-'<<month<<'-'<<day<<endl;
}
return 0;
}
打印日期

链接: 打印日期
思路:先用sday存放一下总天数,然后将sday判断这年是不是闰年,然后用while循环将sday拆成day和month,每次day++,sday–,直到sday等于0。
然后记得判断day是不是达到了该月的最大天数,是的话重置一下,还要判断一下月是不是大于12,是的话也要重置一下。
代码:
#include<iostream>
using namespace std;
int main()
{
int arr[13]={
0,31,28,31,30,31,30,31,31,30,31,30,31};
int year=0,month=1,day=0,sday=0;
cin>>year>>sday;
//判断一下是不是闰年
if((year % 4 ==0 && year % 100 != 0) || (year % 400 == 0))
arr[2]=29;
//将总天数转化成月和天
while(sday > 0)
{
day++;
if(day > arr[month])
{
day=1;
month++;
if(month > 12)
{
month=1;
year++;
}
}
sday--;
}
//判断一下天数和月打印的格式
if(day<10 && month<10)
cout<<year<<"-0"<<month<<"-0"<<day<<endl;
else if(day<10 && month>=10)
cout<<year<<'-'<<month<<"-0"<<day<<endl;
else if(day>=10 && month<10)
cout<<year<<"-0"<<month<<'-'<<day<<endl;
else
cout<<year<<'-'<<month<<'-'<<day<<endl;
//因为有多组测试用例,所有要重置
arr[2]=28;
month=day=1;
return 0;
}
日期差值

链接: 日期差值
思路:先把两个数的年月日分别用三个变量存起来,保持max部分为大的日期,min为小的日期。
然后开始循环,直到min的年月日等于max的年月日为止,用count来统计他们之间相差的天数。
记得判断天是否超过了当月的天数和月数是否超过12月,有的话重置一下!
代码:
#include<iostream>
using namespace std;
int main()
{
int arr[13]={
0,31,28,31,30,31,30,31,31,30,31,30,31};
int day1,day2,count=0;
cin>>day1>>day2;
//保持max为大的那个数,然后分解出来
int max=day1>day2?day1:day2;
int maxday=max%100;
int maxmonth=(max/100)%100;
int maxyear=max/10000;
//保持min为小的那个数,然后分解出来
int min=day1>day2?day2:day1;
int minday=min%100;
int minmonth=(min/100)%100;
int minyear=min/10000;
//直到三个值相等才退出循环
while((minyear!=maxyear)||(minmonth!=maxmonth)||(minday<=maxday))
{
count++;
minday++;
//判断一下天数是否超过当月的最大天数
if(minday>arr[minmonth])
{
minday=1;
minmonth++;
//判断一下月数是否超过12
if(minmonth>12)
{
minmonth=1;
minyear++;
}
}
}
cout<<count;
return 0;
}

边栏推荐
- Beijing internal promotion | the machine learning group of Microsoft Research Asia recruits full-time researchers in nlp/ speech synthesis and other directions
- MySQL之知识点(六)
- 请问下为啥有的表写sql能查到数据,但在数据地图里查不到啊,查表结构也搜不到
- 【二叉树】根到叶路径上的不足节点
- 为什么阳历中平年二月是28天
- 漫画:如何实现大整数相乘?(上) 修订版
- 一文了解MySQL事务隔离级别
- 服务器配置 jupyter环境
- The five most difficult programming languages in the world
- 漫画:寻找股票买入卖出的最佳时机
猜你喜欢

提高應用程序性能的7個DevOps實踐

WR | Jufeng group of West Lake University revealed the impact of microplastics pollution on the flora and denitrification function of constructed wetlands

ICML 2022 | Meta propose une méthode robuste d'optimisation bayésienne Multi - objectifs pour faire face efficacement au bruit d'entrée
Redis+caffeine two-level cache enables smooth access speed
Example tutorial of SQL deduplication

VBA drives SAP GUI to realize office automation (II): judge whether elements exist

Use of ThinkPHP template

mongodb(快速上手)(一)

ICML 2022 | meta proposes a robust multi-objective Bayesian optimization method to effectively deal with input noise

7. Scala class
随机推荐
Cartoon: how to multiply large integers? (next)
漫画:寻找股票买入卖出的最佳时机
漫画:如何实现大整数相乘?(下)
Design of electronic clock based on 51 single chip microcomputer
Troubleshooting - about clip not found Visual Studio
ICML 2022 | Meta propose une méthode robuste d'optimisation bayésienne Multi - objectifs pour faire face efficacement au bruit d'entrée
WebApp开发-Google官方教程
C#实现水晶报表绑定数据并实现打印3-二维码条形码
基于51单片机的电子时钟设计
Rider 设置选中单词侧边高亮,去除警告建议高亮
力扣解法汇总1200-最小绝对差
Cartoon: how to multiply large integers? (I) revised version
Cartoon: looking for the best time to buy and sell stocks
解决“双击pdf文件,弹出”请安装evernote程序
Ant financial's sudden wealth has not yet begun, but the myth of zoom continues!
How to write a full score project document | acquisition technology
SQL删除重复数据的实例教程
菜刀,蚁剑,冰蝎,哥斯拉的流量特征
Cartoon: how to multiply large integers? (integrated version)
ThoughtWorks global CTO: build the architecture according to needs, and excessive engineering will only "waste people and money"