KY258 日期累加

KY258 日期累加

cpp 复制代码
int main()
{
	int n = 0;       //样例个数
	cin >> n;

	//for循环处理n个样例
	for (int i = 0; i < n; i++)
	{
		int y, m, d, num;
		int days[12] = { 31,28,31,30,31,30,31,31,30,31,30,31 };
		//输入年月日 要加的天数
		cin >> y >> m >> d >> num;

		d += num;
		//超过当月
		while (d > days[m - 1])
		{
			//当前年份 二月所含天数
			if (y % 400 == 0 || (y % 4 == 0 && y % 100 != 0))
				days[1] = 29;
			else
				days[1] = 28;

			//减去当月天数 月份++
			d -= days[m - 1];
			m++;

			//天数减成0 不存在0号   自动更新为下一月的1号
			if (d == 0)
				d = 1;
			//月份加成13 不存在13月 自动更新为下一年的1月
			if (m == 13)
			{
				y++;
				m = 1;
			}
		}
		printf("%4d-%02d-%02d\n", y, m, d);
	}
	return 0;
}

这道题会输入一个数: 样例的个数 我们需要对每个样例处理一次

在每个样例中 我们定义一个天数数组

当天天数 + 要增加的天数 结果有3种

1.未超过当月 不做处理

2.超过当月 减去当月天数 月份++

3.超过当年

相关推荐
老王熬夜敲代码9 分钟前
C++中的thread
c++·笔记·面试
qq_4798754338 分钟前
C++ 鸭子类型” (Duck Typing)
开发语言·c++
崇山峻岭之间1 小时前
C++ Prime Plus 学习笔记033
c++·笔记·学习
暗然而日章1 小时前
C++基础:Stanford CS106L学习笔记 7 类
c++·笔记·学习
im_AMBER1 小时前
Leetcode 72 数组列表中的最大距离
c++·笔记·学习·算法·leetcode
Dream it possible!2 小时前
LeetCode 面试经典 150_图的广度优先搜索_最小基因变化(93_433_C++_中等)(广度优先搜索(BFS))
c++·leetcode·面试·广度优先
steins_甲乙3 小时前
C++并发编程
开发语言·c++
南莺莺5 小时前
二叉排序树的创建和基本操作---C++实现
数据结构·c++·算法··二叉排序树
仰泳的熊猫5 小时前
1061 Dating
数据结构·c++·算法·pat考试
Fcy6485 小时前
二叉搜索树(C++实现)
开发语言·数据结构·c++·二叉搜索树