OpenJ_Bailian - 2967
特殊日历计算
有一种特殊的日历法,它的一天和我们现在用的日历法的一天是一样长的。它每天有10个小时,每个小时有100分钟,每分钟有100秒。10天算一周,10周算一个月,10个月算一年。现在要你编写一个程序,将我们常用的日历法的日期转换成这种特殊的日历表示法。这种日历法的时、分、秒是从0开始计数的。日、月从1开始计数,年从0开始计数。秒数为整数。假设 0:0:0 1.1.2000 等同于特殊日历法的 0:0:0 1.1.0。
Input
第一行是一个正整数 N ,表明下面有 N 组输入。每组输入有一行,格式如下:hour:minute:second day.month.year
表示常规的日期。日期总是合法的。2000 <= year <= 50000。
Output
第一行是一个正整数 N ,表明下面有 N 组输入。每组输入有一行,格式如下:hour:minute:second day.month.year
表示常规的日期。日期总是合法的。2000 <= year <= 50000。
例
输入
7 0:0:0 1.1.2000 10:10:10 1.3.2001 0:12:13 1.3.2400 23:59:59 31.12.2001 0:0:1 20.7.7478 0:20:20 21.7.7478 15:54:44 2.10.20749
输出
0:0:0 1.1.0 4:23:72 26.5.0 0:8:48 58.2.146 9:99:98 31.8.0 0:0:1 100.10.2000 0:14:12 1.1.2001 6:63:0 7.3.6848
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<iostream>
using namespace std;
int main()
{
int n;
int m[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
int y[100010];
for(int i=1;i<=100000;i++)
{
if(i%4==0&&i%100!=0||i%400==0)
y[i]=366;
else
y[i]=365;
}
cin>>n;
int a,b,c,d,e,f;
while(n--)
{
scanf("%d:%d:%d%d.%d.%d",&a,&b,&c,&d,&e,&f);
int p=(a*3600+b*60+c)/0.864;
int a1=p/10000;
int b1=p/100%100;
int c1=p%100;
int day=0;
for(int i=2000;i<f;i++)
day+=y[i];
for(int i=1;i<e;i++)
day+=m[i];
if(y[f]==366&&e>2)
day++;
day+=d;
int d1=day%100;
int e1=day/100%10+1;
int f1=day/1000;
if(e1==1&&d1==0)
{
f1--;
d1=100;
e1=10;
}
else if(d1==0)
{
e1--;
d1=100;
}
cout<<a1<<":"<<b1<<":"<<c1<<" "<<d1<<"."<<e1<<"."<<f1<<endl;
}
}