前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C++031-C++日期模拟

C++031-C++日期模拟

作者头像
用户2225445
发布2023-10-16 17:09:22
1570
发布2023-10-16 17:09:22
举报
文章被收录于专栏:IT从业者张某某

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

代码语言:javascript
复制
#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中 如下:

代码语言:javascript
复制
#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

代码语言:javascript
复制
#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++时间模拟相关案例练习。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-02-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • C++031-C++日期模拟
    • 日期模拟
      • 在线练习:
        • 总结
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档