|
||||||
Time | ||||||
|
||||||
Description | ||||||
Kim是一個掌控時間的大師。不同於一般人,他習慣使用秒來計算時間。如果你問他現在是幾點,他會告訴你現在是今天的xxxx秒。Mik想要考考Kim。他想知道從某一天的00:00:00開始,經過s秒後是哪一天。但是Mik不會計算答案,他需要你的幫助。 注意:我們認爲一天從00:00:00開始,到23:59:59結束。00:00:00經過1秒後是00:00:01;從00:00:00開始,加86400(60*60*24)秒後就是下一天的00:00:00. |
||||||
Input | ||||||
第一行一個整數T表示數據組數。 接下來T行,每行一個日期yyyy-MM-dd,接下來一個整數s表示s秒。 |
||||||
Output | ||||||
對於每個輸入,輸出一行yyyy-MM-dd 表示答案。對於不足兩位的數要補齊前導0。 |
||||||
Sample Input | ||||||
3
2016-12-10 1000
2016-02-28 86400
2016-01-01 1000000
|
||||||
Sample Output | ||||||
2016-12-10
2016-02-29
2016-01-12
|
||||||
Hint | ||||||
T<=100 s<=2147483647 日期在1800-01-01到2100-01-01之間 閏年的判斷: 1.能被4整除且不能被100整除的爲閏年. 2.能被400整除的是閏年. |
代碼:
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define fo(i,a,b) for(int i=a;i<=b;i++)
#define fd(i,a,b) for(int i=a;i>=b;i--)
#define inf 0x3f3f3f3f
#define ll long long
#define mem(a,b) memset(a,b,sizeof(a))
using namespace std;
int leap(int y)
{
if((y%4==0&&y%100!=0)||y%400==0)
return 1;
else
return 0;
}
int fun(int y,int m)
{
if(m==2)
{
if(leap(y)==1)
return 29;
else
return 28;
}
else if(m==1||m==3||m==5||m==7||m==8||m==10||m==12)
{
return 31;
}
else
return 30;
}
int main()
{
int t;scanf("%d",&t);
while(t--)
{
int y,m,d;int s;
scanf("%d-%d-%d%d",&y,&m,&d,&s);
//scanf("",);
int day=s/86400.0;
// printf("%d-%.2d-%.2d\n",y,m,d);
for(int i=1;i<=day;i++)
{
d++;
if(d>fun(y,m))//超過天數,月份加一,天數變成一
{
d=1;
m++;
}
if(m>12)//超過月數,年份加一,月份變爲一
{
m=1;
y++;
}
}
printf("%d-%.2d-%.2d\n",y,m,d);
}
}