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;
}
相关推荐
czy878747510 小时前
深入了解 C++ 中的 Lambda 表达式(匿名函数)
c++
2302_8138062210 小时前
【嵌入式修炼:数据结构篇】——树和二叉树
数据结构
52Hz11810 小时前
力扣230.二叉搜索树中第k小的元素、199.二叉树的右视图、114.二叉树展开为链表
python·算法·leetcode
苦藤新鸡10 小时前
56.组合总数
数据结构·算法·leetcode
菜鸟233号10 小时前
力扣647 回文子串 java实现
java·数据结构·leetcode·动态规划
LiLiYuan.10 小时前
【Cursor 中找不到LeetCode 插件解决办法】
算法·leetcode·职场和发展
Charlie_lll10 小时前
力扣解题-[3379]转换数组
数据结构·后端·算法·leetcode
CSDN_RTKLIB10 小时前
include_directories和target_include_directories说明
c++
captain37610 小时前
Java队列(Queue)
算法·链表