题目描述
在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
请严格按照格式书写。不能出现其它文字或符号。
样例输入
2015 1 1 15
2014 11 9 1000
样例输出
2015-01-16
2017-08-05
Code:
#include<stdio.h>
#include<string.h>
#include<iostream>
#include<string>
using namespace std;
int main(){
int y,d,m,n;
while(cin>>y>>m>>d>>n){
int month[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
// if( ((y%4==0)&&(y%100!=0))||(y%400==0) ){
// month[2] = 29;//闰年为29
// }else{
// month[2] = 28;
// }
for(int i=0;i<n;i++){
if( ((y%4==0)&&(y%100!=0))||(y%400==0) ){
month[2] = 29;//闰年为29
}else{
month[2] = 28;
}
d++;
if(d == month[m]+1){
d=1;
m++;
}
if(m == 13){
//d =1;
m=1;
y++;
}
}
printf("%04d-%02d-%02d\n",y,m,d);
//cout<<y<<'-'<<m<<'-'<<d;
}
return 0;
}
思路:
- 相当于时间的递增。
- 如果只是 天数的增加,只需要 day+1 即可。
d++;
- 当天数增加到 一定程度,就需要 月份加一,month+1. 所以需要知道,什么时候才能达到 满天。
这时候需要一个数组存储 每月共有几天。 即
int month[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
同时,需要判断是否是闰年,以此确定 :二月的天数。
4.当 月份增加到 一定程度,就需要 年份+1. 即year+1