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;
}
相关推荐
2501_94132972几秒前
【目标检测】YOLO13-C3k2-PPA改进算法实现门检测与识别实战指南_1
人工智能·算法·目标检测
e***98573 分钟前
C++跨平台开发的5大核心挑战与突破
开发语言·c++
楚来客3 分钟前
AI基础概念之十一:CNN算法的基本原理
人工智能·算法·cnn
listhi5204 分钟前
空间机器人动力学正逆解及遗传算法路径规划(MATLAB实现)
算法·matlab·机器人
橘颂TA8 分钟前
【剑斩OFFER】算法的暴力美学——leetCode 662 题:二叉树最大宽度
c++·算法·结构与算法
zl_vslam10 分钟前
SLAM中的非线性优-3D图优化之绝对位姿SE3约束左扰动(十六)
人工智能·算法·计算机视觉·3d
MSTcheng.10 分钟前
【C++】开放定址法实现哈希表!
c++·缓存·stl·散列表·哈希
a努力。10 分钟前
得物Java面试被问:B+树的分裂合并和范围查询优化
java·开发语言·后端·b树·算法·面试·职场和发展
beiguang_jy11 分钟前
线离线TOC总有机碳测试仪
大数据·人工智能·科技·算法·制造·零售·风景
玖釉-12 分钟前
[Vulkan 学习之路] 20 - 顶点缓冲区:创建顶点缓冲区 (Vertex Buffer Creation)
c++·windows·图形渲染