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

news2025/7/22 10:35:33

文章目录

  • 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++时间模拟相关案例练习。

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

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

相关文章

CSS 网页动画【快速掌握知识点】

目录 前言 一、使用CSS3动画 二、使用CSS过渡 三、使用CSS变换&#xff1a; 前言 CSS是一种用于网页设计和排版的语言&#xff0c;也可以用它来制作网页动画。 一、使用CSS3动画 CSS3引入了动画属性&#xff0c;允许您为元素设置动画效果。您可以使用关键帧来定义动画的开始…

MVP简单模型搭建【架构】

MVP简介 MVP是一种项目架构设计模式&#xff08;说白了就是我们产品的一种设计方案&#xff09; 其实MVP本质 就是将View和Model完全隔离&#xff0c;通过Presenter统一调度管理&#xff08;Presenter扮演着中介的角色&#xff09;传统的设计思路是我们直接跟房东谈&#xff0…

聊聊动态线程池的9个场景(改进版)

线程池是一种基于 池化思想管理线程 的工具&#xff0c;使用线程池可以减少 创建销毁线程的开销&#xff0c;避免线程过多导致 系统资源耗尽。在 高并发以及大批量 的任务处理场景&#xff0c;线程池的使用是必不可少的。 如果有在项目中实际使用线程池&#xff0c;相信你可能…

数仓模型之维度建模

目录 1、数仓架构原则 2、如何搭建一个好的数仓 2.1 建模方法 2.2 建模解决的痛点 2.3 数仓系统满足的特性 2.4 数仓架构设计 3、维度建模 4、案例 5、问题讨论 今天我们来聊聊在数仓模型中举足轻重的维度建模。 简单而言&#xff0c;数据仓库的核心目标是为展现层提…

Hive学习——开窗函数精讲

目录 一、基于行的窗口函数——行的起点~行的终点 二、基于值的窗口函数——值的起点~值的终点 三、基于分区的窗口函数 四、基于缺省的窗口函数 五、lead与lag 六、first_value和last_value 七、排名函数——rank(113)、dense_rank(112)、row_number(123) 八、NTILE分…

nvm (node版本管理工具)安装的详细步骤,并解决安装过程中遇到的问题

1、下载NVM&#xff0c;跳转下载链接后&#xff0c;如下图&#xff0c;下载红框后解压文件 2、安装 注意&#xff1a;双击安装之后&#xff0c;会有两个地址选择&#xff0c; 1、地址中不能存在空格 2、不要放在C盘中&#xff0c;后面需要改个设置文件&#xff0c;安装到C盘的…

银行家算法

银行家算法 银行家算法是一种用来避免操作系统死锁出现的有效算法&#xff0c;所以在引入银行家算法的解释之前&#xff0c;有必要简单介绍一下死锁的概念。 一、死锁 死锁&#xff1a;是指两个或两个以上的进程在执行过程中&#xff0c;由于竞争资源或者由于彼此通信而造成…

Gitlab Linux 环境安装

环境检查是否已经安装了gitlab&#xff0c;安装了需要卸载# 检查当前环境是否已经安装了gitlab&#xff0c;并且查看版本 gitlab-rails console # 删除命令 yum remove git# 查找命令 rpm -qa | grep gitlab # 删除命令 rpm -e gitlab-ce-12.10.1-ce.0.el8.x86_64 # 查找命令f…

DS期末复习卷(八)

一、选择题(30分) 1.字符串的长度是指&#xff08; C &#xff09;。 (A) 串中不同字符的个数 (B) 串中不同字母的个数 (C ) 串中所含字符的个数 (D) 串中不同数字的个数 2.建立一个长度为n的有序单链表的时间复杂度为&#xff08; C &#xff09; (A) O(n) (B) O(1) © …

小米/红米手机数据恢复:从小米手机恢复已删除的数据

如果您不小心删除了小米手机上的数据&#xff0c;后来发现您需要它&#xff0c;那么本文适合您。我将向您介绍一些最可靠的小米恢复方法&#xff0c;以将您的数据恢复到您的设备上。无论您是否有备份&#xff0c;都可以处理。让我们开始吧&#xff01; 小米数据恢复 - 如何做&a…

一篇学习JVM

基础入门 1.JDK、JRE、JVM三者间的联系与区别 JDK JDK(Java SE Development Kit)&#xff0c;Java标准开发包&#xff0c;它提供了编译、运行Java程序所需的各种工具和资源&#xff0c;包括Java编译器、Java运行时环境&#xff0c;以及常用的Java类库等。 下图是JDK的安装目…

博客管理系统--项目说明

项目体验地址&#xff08;账号&#xff1a;123&#xff0c;密码&#xff1a;123&#xff09;http://120.53.20.213:8080/blog_system/login.html项目码云Gitee地址&#xff1a;https://gitee.com/GoodManSS/project/tree/master/blog_system&#xff08;一&#xff09;准备工作…

【ArcGIS Pro二次开发】(7):地图(Map)的基本操作

地图是ArcGIS Pro中的基础起点&#xff0c;也是大多数工程的基础。主要用于显示表示空间数据的图层。 一、地图(Map)的基本操作示例 1、获取当前地图 var map MapView.Active.Map; 2、获取一级图层 var lys map.Layers; 用于获取地图中的单一图层&#xff0c;以及图层组…

【正点原子FPGA连载】第十六章DP彩条显示实验 摘自【正点原子】DFZU2EG_4EV MPSoC之嵌入式Vitis开发指南

1&#xff09;实验平台&#xff1a;正点原子MPSoC开发板 2&#xff09;平台购买地址&#xff1a;https://detail.tmall.com/item.htm?id692450874670 3&#xff09;全套实验源码手册视频下载地址&#xff1a; http://www.openedv.com/thread-340252-1-1.html 第十六章DP彩条显…

什么是路由?

什么是路由&#xff1f; 介绍 **路由是指路由器从一个接口上收到数据包&#xff0c;根据数据包的目的地址进行定向并转发到另一个接口的过程。**路由发生在OSI网络参考模型中的第三层即网络层。 路由引导分组转送&#xff0c;经过一些中间的节点后&#xff0c;到它们最后的目…

六【 SpringMVC框架】

一 SpringMVC框架 目录一 SpringMVC框架1.什么是MVC2.SpringMVC概述3.SpringMVC常见开发方式4.SpringMVC执行流程5.SpringMVC核心组件介绍6.快速构建Spring MVC程序✅作者简介&#xff1a;Java-小白后端开发者 &#x1f96d;公认外号&#xff1a;球场上的黑曼巴 &#x1f34e;个…

工业三防平板可应用于各种复杂苛刻的工作环境

伴随着工业互联网技术的快速发展&#xff0c;生产制造自然环境繁杂&#xff0c;机器设备规定比较严苛。普通平板在工业场景户外场景等都比较容易出现磕碰或者出现其它因素如进水、进灰尘而引发设备故障。三防平板之所以在建筑工程的应用较为广泛&#xff0c;这与其独特的性能是…

线性数据结构:数组 Array

一、前言数组是数据结构还是数据类型&#xff1f;数组只是个名称&#xff0c;它可以描述一组操作&#xff0c;也可以命名这组操作。数组的数据操作&#xff0c;是通过 idx->val 的方式来处理。它不是具体要求内存上要存储着连续的数据才叫数组&#xff0c;而是说&#xff0c…

scratch和平使者 电子学会图形化编程scratch等级考试一级真题和答案解析2022年12月

目录 scratch和平使者 一、题目要求 1、准备工作 2、功能实现 二、案例分析

视图、游标、慢查询日志

Java知识点总结&#xff1a;想看的可以从这里进入 目录2.7、视图、游标2.7.1、视图2.7.2、游标2.7、慢查询日志2.7、视图、游标 2.7.1、视图 视图是一种虚拟存在的表&#xff0c;同真实表一样&#xff0c;视图也由列和行构成&#xff0c;它不存在于数据库中&#xff0c;是我们…