题目描述
在X星系的广袤空间中漂浮着许多X星人造“炸弹”,用来作为宇宙中的路标。
每个炸弹都可以设定多少天之后爆炸。
比如:阿尔法炸弹2015年1月1日放置,定时为15天,则它在2015年1月16日爆炸。
有一个贝塔炸弹,a年b月c日放置,定时为n天,请你计算它爆炸的准确日期。
输入
输入存在多组数据,每组数据输入一行,每一行输入四个正整数a,b,c,n
输入保证日期在1000-01-01到2020-01-01之间,且日期合法。
n不超过1000
输出
请填写该日期,格式为 yyyy-mm-dd 即4位年份2位月份2位日期。比如:2015-02-19
请严格按照格式书写。不能出现其它文字或符号。
样例输入 Copy
2015 1 1 15 2014 11 9 1000
样例输出 Copy
2015-01-16 2017-08-05
这题应该注意年月日的增加的方法每次当月份到12时其余的日或年如何变化
#include <iostream>
using namespace std;
void JudgeLeapYear(int a, int month[])
{
if(a % 400 == 0 || (a % 4 == 0 && a % 100 != 0))
month[1] = 29;
else
month[1] = 28;
}
int main()
{
int a, b, c, n;
int month[12] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
while(cin >> a >> b >> c >> n)
{
while(n)
{
JudgeLeapYear(a, month);
while(b <= 12)
{
if(!n)
break;
while(c < month[b - 1])
{
if(!n)
break;
c ++ ;
n -- ;
}
if(!n)
break;
b ++ ;
c = 0;
}
if(!n)
break;
a ++ ;
b = 1;
}
if(b >= 10 && c >= 10)
cout << a << '-' << b << '-' << c << endl;
else
if(b < 10 && c >= 10)
cout << a << '-' << '0' << b << '-' << c << endl;
else
if(b >= 10 && c < 10)
cout << a << '-' << b << '-' << '0' << c << endl;
else
cout << a << '-' << '0' << b << '-' << '0' << c << endl;
}
return 0;
}