文章目录
- C++031-C++日期模拟
- 日期模拟
- 题目描述 给出天数求月份日期
- 题目描述 给出天数求月份日期-倒计时
- 题目描述 求任意日期插值
- 在线练习:
- 总结
C++031-C++日期模拟
在线练习:
http://noi.openjudge.cn/
https://www.luogu.com.cn/
日期模拟
题目描述 给出天数求月份日期
给定一个年份y和一个整数d,问这一年的第d天是几月几日?
注意闰年的2月有29天。满足下面条件之一的是闰年:
1、年份是4的整数倍,而且不是100的整数倍;
2、年份是400的整数倍。
输入:
年份 和 天数
输出:
返回2行,一行是月份 第二行是天数
样例输入:
2000 360
样例输出:
12 25
#include <iostream>
//#include<bits/stdc++.h>
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 i=1;i<=12;i++){
n-=day[i]; //天数-月份的天数
if(n<=0){ //剩余天数小于0 表示月份为当前月
cout<<i<<endl; //输出月份
cout<<day[i]+n; // 输出剩余的天数
break;
}
// if(n==0){ //恰好是整数月份
// cout<<i<<endl; //输出当前月份
// cout<<day[i];
// break;
// }
}
return 0;
}
输出为:
题目描述 给出天数求月份日期-倒计时
输入一个日期,求该日期与2015年5月17日相差有多少天。注意要求输入的日期小于2015年5月17日。
注意闰年的2月有29天。满足下面条件之一的是闰年:
1、年份是4的整数倍,而且不是100的整数倍;
2、年份是400的整数倍。
输入:
年份 和 天数
输出:
返回2行,一行是月份 第二行是天数
样例输入:
2000 360
样例输出:
12 25
思路1
假设输入的时间为m年n月d日
则先计算m年1月1日到m年n月d日的天数 记为 s1
计算m年1月1日到2014年12月31日的天数 记为s2
计算2015年1月1日到2015年4月17日的天数 记为s3
总天数为 s2+s3 -(s1+1)
思路2
假设输入的时间为m年n月d日
则先计算m年到2015年的完整年份天数,如输入的是2012年3月17日,则计算2013+2014年的完整天数,365+365=730天。
如果输入的年份为2015年,累计完整月数天数到s。然后分为两种情况,一种是为2015年5月,一种是非5月。如果为5月,天数为17-d,如果为非5月,天数为非5月的天数-d+17,如2015年4月17日,则为4月的天数30-d的数字17+17(5月17日)=30天。把天数累计到s。
如果输入的年份不为2015年,累计2015年1月1日到5月17日的日期到s。计算m年n月-m年12月的完整月数天数到s。然后计算当月的天数为day[n]-d,把天数累计到s。如输入的是2012年3月17日,则2012年3月-2012年12月的完整月数天数为
for(int i=n+1;i<=12;i++) s+=day[i];
当月的天数为day[n]-d为31-17=14天,把14天也累加到s中
如下:
#include <iostream>
//#include<bits/stdc++.h>
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 s;//计算总天数
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<2015;i++){ //如果年份小于2014年,如输入2013,则计算2014年完整年份天数
if (check(i)) s+=366;
else s+=365;
}
if(m==2015){ //如果输入的年份为2015
for(int i=n+1;i<5;i++){//计算完整的月份天数 如输入2月。则计算累加3,4月的完整天数
s+=day[i];//完整的月份
}
if(n==5){//如果月份恰好为5月,相差时间为17-d
s+=17-d;
}
else{//如果不是5月,如输入2月,s累加2月当月的天数-d + 17天
s+=day[n]-d+17;
}
}
else{ //如果输入的不是2015年
s += (day[1]+day[2]+day[3]+day[4]+17); //计算2015年1月1日到5月17日的天数
for(int i=n+1;i<=12;i++){
s+=day[i];//计算当年到年底的天数如2月17日,则计算3-12月的天数
}
s+=day[n]-d;//s加上当月的剩余天数
}
cout<<s<<endl;
return 0;
}
题目描述 求任意日期插值
参考:https://blog.csdn.net/hou1620089770/article/details/107219855/
有两个日期,计算它们之间的差值,如果两个日期是连续的,则按照2天算。
日期格式规定为YYYYMMDD,例如20200709
基本思路
(1)输入两个日期
(2)以小的日期为底,每次加一天,直到与大的日期相等即可
(2.1)增加一天后,月份,年份都可能会随之变化。针对闰年平年以及大小月天数都一样,采用一个12*2的二维数组列出12月的润平年的天数。
(2.2)当达到月份的天数时,月份加1
(2.3)当达到12个月时,年份加1
#include <iostream>
#include <stdio.h>
#include <algorithm>
using namespace std;
bool isLeap(int year) {
return (year % 4 == 0) && (year % 100 != 0) || (year % 400 == 0);
}
int main() {
//定义好平年和闰年每月的天数
int monthDays[13][2] = {
{0,0},{31,31},{28,29},{30,30},{31,31},{30,30},
{31,31},{30,30},{31,31},{30,30},{31,31},{30,30},
{31,31}
};
int time1, year1, month1, days1;
int time2, year2, month2, days2;
int numbers =1;
// 输入两个日期
cout << "输入两个日期,空格分隔";
cin >> time1 >> time2;
if (time1>time2){
int temp = time1;
time1 = time2;
time2 = temp;
}
//拆解日期,分为年,月,号
year1 = time1 / 10000; month1 = time1 / 100 % 100; days1 = time1 % 100;
year2 = time2 / 10000; month2 = time2 / 100 % 100; days2 = time2 % 100;
//第一个日期 累加到 第二个日期
while (year1 < year2 || month1 < month2 || days1 < days2) {
days1++;// 在第一个日期基础上 加一天
//加一天后,相应的月,年可能也要做一定的变化
if (days1 == monthDays[month1][isLeap(year1)]+1) {//当前号超过当前月最高天数:月份加1,号变成下月的1号
month1++;
days1 = 1;
}
if (month1 == 13) {//月份超过12个月 :年份加1,月份变成下年的1月
year1++;
month1 = 1;
}
numbers++;
}
cout << numbers << endl;
return 0;
}
在线练习:
http://noi.openjudge.cn/
总结
本系列为C++学习系列,会介绍C++基础语法,基础算法与数据结构的相关内容。本文为C++时间模拟相关案例练习。