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;
}
相关推荐
惯导马工1 小时前
【论文导读】ORB-SLAM3:An Accurate Open-Source Library for Visual, Visual-Inertial and
深度学习·算法
骑自行车的码农2 小时前
【React用到的一些算法】游标和栈
算法·react.js
博笙困了3 小时前
AcWing学习——双指针算法
c++·算法
感哥3 小时前
C++ 指针和引用
c++
moonlifesudo3 小时前
322:零钱兑换(三种方法)
算法
感哥14 小时前
C++ 多态
c++
沐怡旸20 小时前
【底层机制】std::string 解决的痛点?是什么?怎么实现的?怎么正确用?
c++·面试
NAGNIP21 小时前
大模型框架性能优化策略:延迟、吞吐量与成本权衡
算法
美团技术团队1 天前
LongCat-Flash:如何使用 SGLang 部署美团 Agentic 模型
人工智能·算法
River4161 天前
Javer 学 c++(十三):引用篇
c++·后端