百练 2966 时区转换 解题报告

1.链接:http://poj.grids.cn/practice/2966/

2.题目:

总时间限制:
1000ms
内存限制:
65536kB
描述
直到19世纪,时间校准是一个纯粹的地方现象。每一个村庄当太阳升到最高点的时候把他们的时钟调到中午12点。一个钟表制造商人家或者村里主 表的时间被认为是官方时间,市民们把自家的钟表和这个时间对齐。每周一些热心的市民会带着时间标准的表,游走大街小巷为其他市民对表。在城市之间旅游的 话,在到达新地方的时候需要把怀表校准。但是,当铁路投入使用之后,越来越多的人频繁地长距离地往来,时间变得越来越重要。在铁路的早期,时刻表非常让人 迷惑,每一个所谓的停靠时间都是基于停靠地点的当地时间。时间的标准化对于铁路的高效运营变得非常重要。
在1878年,加拿大人Sir Sanford Fleming 提议使用一个全球的时区(这个建议被采纳,并衍生了今天我们所使用的全球时区的概念),他建议把世界分成24个时区,每一个跨越15度经线(因为地球的经 度360度,划分成24块后,一块为15度)。Sir Sanford Fleming的方法解决了一个全球性的时间混乱的问题。
美国铁路公司 于1883年11月18日使用了Fleming 提议的时间方式。1884年一个国际子午线会议在华盛顿召开,他的目的是选择一个合适的本初子午线。大会最终选定了格林威治为标准的0度。尽管时区被确定 了下来,但是各个国家并没有立刻更改他们的时间规范,在美国,尽管到1895年已经有很多州开始使用标准时区时间,国会直到1918年才强制使用会议制定 的时间规范。
今天各个国家使用的是一个Fleming时区规范的一个变种,中国一共跨越了5个时区,但是使用了一个统一的时间规范,比 Coordinated Universal Time(UTC,格林威制时间)早8个小时。俄罗斯也拥护这个时区规范,尽管整个国家使用的时间和标准时区提前了1个小时。澳大利亚使用3个时区,其中 主时区提前于他按Fleming规范的时区半小时。很多中东国家也使用了半时时区(即不是按照Fleming的24个整数时区)。
因为时区是对经度进行划分,在南极或者北极工作的科学家直接使用了UTC时间,否则南极大陆将被分解成24个时区。
时区的转化表如下:
UTC Coordinated Universal Time
GMT Greenwich Mean Time, 定义为 UTC
BST British Summer Time, 定义为 UTC+1 hour
IST Irish Summer Time, 定义为 UTC+1 hour
WET Western Europe Time, 定义为 UTC
WEST Western Europe Summer Time, 定义为 UTC+1 hour
CET Central Europe Time, 定义为 UTC+1
CEST Central Europe Summer Time, 定义为 UTC+2
EET Eastern Europe Time, 定义为 UTC+2
EEST Eastern Europe Summer Time, 定义为 UTC+3
MSK Moscow Time, 定义为 UTC+3
MSD Moscow Summer Time, 定义为 UTC+4
AST Atlantic Standard Time, 定义为 UTC-4 hours
ADT Atlantic Daylight Time, 定义为 UTC-3 hours
NST Newfoundland Standard Time, 定义为 UTC-3.5 hours
NDT Newfoundland Daylight Time, 定义为 UTC-2.5 hours
EST Eastern Standard Time, 定义为 UTC-5 hours
EDT Eastern Daylight Saving Time, 定义为 UTC-4 hours
CST Central Standard Time, 定义为 UTC-6 hours
CDT Central Daylight Saving Time, 定义为 UTC-5 hours
MST Mountain Standard Time, 定义为 UTC-7 hours
MDT Mountain Daylight Saving Time, 定义为 UTC-6 hours
PST Pacific Standard Time, 定义为 UTC-8 hours
PDT Pacific Daylight Saving Time, 定义为 UTC-7 hours
HST Hawaiian Standard Time, 定义为 UTC-10 hours
AKST Alaska Standard Time, 定义为 UTC-9 hours
AKDT Alaska Standard Daylight Saving Time, 定义为 UTC-8 hours
AEST Australian Eastern Standard Time, 定义为 UTC+10 hours
AEDT Australian Eastern Daylight Time, 定义为 UTC+11 hours
ACST Australian Central Standard Time, 定义为 UTC+9.5 hours
ACDT Australian Central Daylight Time, 定义为 UTC+10.5 hours
AWST Australian Western Standard Time, 定义为 UTC+8 hours
下面给出了一些时间,请在不同时区之间进行转化。
输入
输入的第一行包含了一个整数N,表示有N组测试数据。接下来N行,每一行包括一个时间和两个时区的缩写,它们之间用空格隔开。时间由标准的a.m./p.m给出。midnight表示晚上12点(12:00 a.m.),noon表示中午12点(12:00 p.m.)。
输出
假设输入行给出的时间是在第一个时区中的标准时间,要求输出这个时间在第二个时区中的标准时间。
样例输入
4

noon HST CEST 

11:29 a.m. EST GMT

6:01 p.m. CST UTC

12:40 p.m. ADT MSK

样例输出
midnight

4:29 p.m.

12:01 a.m.

6:40 p.m.

3.代码:

 1 #include <iostream>

 2 #include <cstdio>

 3 #include <cstdlib>

 4 #include <cstring>

 5 

 6 using namespace std;

 7 

 8 char zone[32][20] = {"UTC","GMT","BST","IST","WET","WEST",

 9                     "CET","CEST","EET","EEST","MSK",

10                     "MSD","AST","ADT","NST","NDT",

11                     "EST","EDT","CST","CDT","MST",

12                     "MDT","PST","PDT","HST","AKST",

13                     "AKDT","AEST","AEDT","ACST","ACDT",

14                     "AWST"};

15 

16 float m_time[32] = {0,0,1,1,0,1,1,2,2,3,3,4,-4,-3,-3.5,-2.5,-5,-4,-6,-5,-7,

17                     -6,-8,-7,-10,-9,-8,10,11,9.5,10.5,8};

18 

19 int main()

20 {

21     int n;

22     cin>>n;

23     getchar();

24     

25     char chs[100];

26     int thour,tminute,minute,diff_minute;

27     float diff_zone;

28     char ch1[20],zone1[20],zone2[20];

29     while(n--)

30     {

31         gets(chs);

32         if(chs[0] == 'n')

33         {

34             sscanf(chs,"%s%s%s",ch1,zone1,zone2);

35             thour = 12;

36             tminute = 0;

37         }

38         else if(chs[0] == 'm')

39         {

40             sscanf(chs,"%s%s%s",ch1,zone1,zone2);

41             thour = 0;

42             tminute = 0;

43         }

44         else

45         {

46             sscanf(chs,"%d:%d %s%s%s",&thour,&tminute,ch1,zone1,zone2);

47             /*if(ch1[0] == 'a')

48             {

49                 if(thour == 12) thour = 0;

50             }

51             else

52             {

53                 if(thour != 12)    thour += 12;

54             }*/

55             thour %= 12;

56             if(ch1[0] == 'p') thour += 12;

57         }

58         

59         minute = thour * 60 + tminute;

60         

61         int m_idx1,m_idx2;

62         for(int i = 0; i < 32; i++)

63         {

64             if(!strcmp(zone[i],zone1)) m_idx1 = i;

65             if(!strcmp(zone[i],zone2)) m_idx2 = i;

66         }

67         diff_zone = m_time[m_idx2] - m_time[m_idx1];

68         minute += (int)(diff_zone * 60);

69         

70         if(minute < 0) minute += 1440;

71         minute %= 1440;

72         

73         thour = minute / 60;

74         tminute = minute % 60;

75         

76         if(thour == 0 && tminute == 0) printf("midnight\n");

77         else if(thour == 0) printf("12:%02d a.m.\n",tminute);

78         else if(thour < 12) printf("%d:%02d a.m.\n",thour,tminute);

79         else if(thour == 12 && tminute == 0) printf("noon\n");

80         else if(thour == 12) printf("12:%02d p.m.\n",tminute);

81         else printf("%d:%02d p.m.\n",thour-12,tminute);

82     }

83     

84     return 0;

85 }

4.思路:

(1)一个不小心,错了N多次

(2)此题目注意时间的表示,比如 12:01 a.m. 指的是凌晨0点01分,注意!这种还有很多要一一注意

(3)可以先转成分钟,然后再计算可以免除很多的麻烦

 

你可能感兴趣的:(转换)