POJ 2210

简介: u问题描述 •有一种特殊的日历法,它的一天和我们现在用的日历法的一天是一样长的。它每天有10个小时,每个小时有100分钟,每分钟有100秒。10天算一周,10周算一个月,10个月算一年。

 

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 2027 No Brainer
POJ 2027 No Brainer
82 0
|
算法框架/工具
POJ 2262 Goldbach's Conjecture
POJ 2262 Goldbach's Conjecture
115 0
|
算法 数据建模 机器学习/深度学习
POJ 1067 取石子游戏
取石子游戏 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 40917   Accepted: 13826 Description 有两堆石子,数量任意,可以不同。
1087 0
poj 3620
题意:给出一个矩阵,其中有些格子干燥、有些潮湿。       如果一个潮湿的格子的相邻的四个方向有格子也是潮湿的,那么它们就可以构成更大       的湖泊,求最大的湖泊。       也就是求出最大的连在一块儿的潮湿的格子的数目。
553 0
poj 2299 求逆序数
http://poj.org/problem?id=2299 #include using namespace std; int aa[500010],bb[500010]; long long s=0; void merge(int l,int m,int r) { ...
767 0
poj-1008-玛雅历
Description 上周末,M.A. Ya教授对古老的玛雅有了一个重大发现。从一个古老的节绳(玛雅人用于记事的工具)中,教授发现玛雅人使用了一个一年有365天的叫做Haab的历法。这个Haab历法拥有19个月,在开始的18个月,一个月有20天,月份的名字分别是pop, no, zip, zotz, tzec, xul, yoxkin, mol, chen, yax, zac, ceh, mac, kankin, muan, pax, koyab, cumhu。
853 0
|
算法 机器人 编译器
POJ-2632
#include int main() { int k,a,b,n,m,i,j,num,rep,rect[100][100],robot[100][3]; int flag; char c; for(scanf("%d...
875 0