描述
有一种特殊的日历法,它的一天和我们现在用的日历法的一天是一样长的。它每天有10个小时,每个小时有100分钟,每分钟有100秒。10天算一周,10周算一个月,10个月算一年。现在要你编写一个程序,将我们常用的日历法的日期转换成这种特殊的日历表示法。这种日历法的时、分、秒是从0开始计数的。日、月从1开始计数,年从0开始计数。秒数为整数。假设 0:0:0 1.1.2000 等同于特殊日历法的 0:0:0 1.1.0。
输入
第一行是一个正整数 N ,表明下面有 N 组输入。每组输入有一行,格式如下:hour:minute:second day.month.year
表示常规的日期。日期总是合法的。2000 <= year <= 50000。
输出
每组输入要求输出一行。格式如下:mhour:mmin:msec mday.mmonth.myear 是输入日期的特殊日历表示方法。
样例输入
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 <iostream>
#include <cstdio>
using namespace std;
int monthdays[12] = {31,28,31,30,31,30,31,31,30,31,30,31};
bool isLeap(int year)
{
if(year%4==0 && (year%100!=0 || year%400==0))
{
return true;
}
return false;
}
int getDays(int year, int month, int day)
{
int days=0;
for(int i=2000;i<year;i++)
{
if(isLeap(i))
{
days += 366;
}else
{
days += 365;
}
}
for(int i=1;i<month;i++)
{
days+=monthdays[i-1];
}
if(month > 2 && isLeap(year))
{
days++;
}
days += day-1;
return days;
}
int main()
{
int mhour,mmin,msec,mday,mmonth,myear,ms=0, n, days=0;
int nhour,nmin,nsec,nday,nmonth,nyear, ns;
scanf("%d", &n);
while(n--)
{
//从2000年开始算
scanf("%d:%d:%d %d.%d.%d", &mhour,&mmin,&msec, &mday,&mmonth,&myear);
days = getDays(myear, mmonth, mday);
nyear = days/1000;
nmonth = days%1000/100+1;
nday = days%1000%100+1;
//正常计算经过了多少秒;
ms = 3600*mhour + 60*mmin + msec;
ns = ms*125/108;
//根据正常日历的s计算出当前日历对应的秒数,计算公式:ms*100000/(3600*24),但是不能直接写成这个公式
nhour = ns/10000;
nmin = ns%10000/100;
nsec = ns%10000%100;
//cout<<nyear<<" "<<nmonth<<" "<<nday<<endl;
printf("%d:%d:%d %d.%d.%d\n", nhour, nmin, nsec, nday, nmonth, nyear);
}
return 0;
}