CSP-CCF 201509-2 日期计算

一、问题描述

问题描述

给定一个年份y 和一个整数d ,问这一年的第d 天是几月几日?

注意闰年的2月有29天。满足下面条件之一的是闰年:

1) 年份是4的整数倍,而且不是100的整数倍;

2) 年份是400的整数倍。

输入格式

输入的第一行包含一个整数y ,表示年份,年份在1900到2015之间(包含1900和2015)。

输入的第二行包含一个整数dd在1至365之间。

输出格式

输出两行,每行一个整数,分别表示答案的月份和日期。

样例输入

2015

80

样例输出

3

21

样例输入

2000

40

样例输出

2

9

二、解答

cpp 复制代码
#include<iostream>
using namespace std;
int main()
{
	int y;
	cin >> y;
	int d;
	cin >> d;
	int day = 0;
	int month = 0;
	int date = 0;
	int b[13] = { 0 };
	if (y % 400 == 0 || (y % 4 == 0 && y % 100 != 0))
	{
		for (int i = 1; i <= 12; i++)
		{
			if(i==2)
			{
				day += 29;
				b[i] = 29;
			}
			if (i == 4 || i == 6 || i == 9 || i == 11)
			{
				day += 30;
				b[i] = 30;
			}
			if (i == 1 || i == 3 || i == 5 || i == 7||i==8||i==10||i==12)
			{
				day += 31;
				b[i] = 31;
			}
			if(day>=d)
			{
				month = i;
				date = b[i] - (day - d);
				cout << month << endl;
				cout << date << endl;
				break;
			}
			
		}
	}
	else {
		for (int i = 1; i <= 12; i++)
		{
			if (i == 2)
			{
				day += 28;
				b[i] = 28;
			}
			if (i == 4 || i == 6 || i == 9 || i == 11)
			{
				day += 30;
				b[i] = 30;
			}
			if (i == 1 || i == 3 || i == 5 || i == 7 || i == 8 || i == 10 || i == 12)
			{
				day += 31;
				b[i] = 31;
			}
			if (day >= d)
			{
				month = i;
				date = b[i] - (day - d);
				cout << month << endl;
				cout << date << endl;
				break;
			}

		}
	}
	return 0;
}
相关推荐
Skrrapper4 分钟前
【编程史】微软的起家之路:一代传奇的诞生
数据库·c++·microsoft
XH华4 分钟前
数据结构第六章:栈的学习
数据结构
Super小白&32 分钟前
C++ 高可用线程池实现:核心 / 非核心线程动态扩缩容 + 任务超时监控
c++·线程池
多多想1 小时前
C++扫盲——为什么C/C++分文件要写h和cpp?
c语言·c++
adam_life1 小时前
【P8306 【模板】字典树】
数据结构·算法·字典树·trie·哈希表··结构体
liulilittle1 小时前
C++判断wchar_t空白字符
开发语言·c++
Wenhao.1 小时前
LeetCode Hot100 腐烂的橘子
算法·leetcode·职场和发展
行走的bug...1 小时前
支持向量机
算法·机器学习·支持向量机
晨非辰1 小时前
算法闯关日记 Episode :解锁链表「环形」迷局与「相交」奥秘
数据结构·c++·人工智能·后端·python·深度学习·神经网络
信号处理学渣1 小时前
matlab之将一个升序数组按照元素值连续与否分成多组
数据结构·算法·matlab