POJ 2210

 

u 问题描述
有一种特殊的日历法,它的一天和我们现在用的日历法的一天是一样长的。它每 天有 10 个小时,每个小时有 100 分钟,每分钟有 100 秒。 10 天算一周, 10 周算一 个月, 10 个月算一年。
现在要你编写一个程序,将我们常用的日历法的日期转换成这种特殊的日历表示 法。这种日历法的时、分、秒是从 0 开始计数的。日、月从 1 开始计数,年从 0 始计数。秒数为整数。假设 0:0:0 1.1.2000 等同于特殊日历法的 0:0:0 1.1.0
  
u 输入
第一行是一个整数 N ,表示测试样例的数目。 每个测试样例包含一行, 格式为: hour:minute:second day.month.year 日期总是合法的, 并且 2000 <= year <= 50000.
u 输出
对于每个测试样例输出一行,该行包含转换后得到的特殊日历表示法, 形如: "mhour:mmin:msec mday.mmonth.myear"
 
#include <stdio.h>
#include<string.h>
#include<stdlib.h>
int leap[50010];
int vis[12]={31,28,31,30,31,30,31,31,30,31,30,31};
void isleap()
{
    int i,j;
    memset(leap,0,sizeof(leap));
    for(i=2000;i<=50000;i++)
    {
         if(i%4==0&&i%100!=0||i%400==0)
            leap[i]=1;
    }
}      
int total_days(int year,int month,int day)
{
    int i,j;int sum=0;
    for(i=2000;i<year;i++)
    if(leap[i])
        sum+=366;
    else 
        sum+=365;
    for(i=0;i<month-1;i++)
        sum+=vis[i];//加上月份天数 
    if(leap[year])
        if(month>2)
            sum++; 
    return sum+day-1;
}
int main()
{
	int i,j,T;
    int hour,minute,sec,day,month,year;
    int mhour,mminute,msec,mday,mmonth,myear;
    int total_day,total_sec,mod;
    scanf("%d",&T);
    isleap();
    while(T--)
    {
    	total_day=total_sec=mod=0;
        scanf("%d%*c%d%*c%d%*c%d%*c%d%*c%d",&hour,&minute,&sec,&day,&month,&year);
        total_day=total_days(year,month,day);
        myear=total_day/1000;
        mod=total_day%1000;
        mmonth=mod/100+1;
        mod%=100;
        /*
        加1是因为total_days();返回的天数不包括当天
        */ 
        mday=mod+1;
        total_sec=(int)((3600*hour+60*minute+sec)*250.0/216);
        /* 
        mday+=total_sec/100000;
        不必要,因为原来的不够一天的 在新日历法中肯定也不够一天
		*/
		mhour=total_sec/10000;//100分钟,100秒
		mod=total_sec%10000;
		mminute=mod/100;
		mod%=100;
		msec= mod;
		/*
		后边两个是点号,吃了一个wa 
        */ 
  		printf("%d:%d:%d %d.%d.%d\n",mhour,mminute,msec,mday,mmonth,myear);
    }
    system("pause");
    return 0;
}            

 

你可能感兴趣的:(poj)