• 百练 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
    ");
    77         else if(thour == 0) printf("12:%02d a.m.
    ",tminute);
    78         else if(thour < 12) printf("%d:%02d a.m.
    ",thour,tminute);
    79         else if(thour == 12 && tminute == 0) printf("noon
    ");
    80         else if(thour == 12) printf("12:%02d p.m.
    ",tminute);
    81         else printf("%d:%02d p.m.
    ",thour-12,tminute);
    82     }
    83     
    84     return 0;
    85 }

    4.思路:

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

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

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

  • 相关阅读:
    SQL 触发器[1]
    SQL 存储过程[1]-常用参数及示例
    前端软件开发体系
    人工智能AI Boosting HMC Memory Chip
    先进一站式IP及定制
    BTC芯片介绍
    ONNX MLIR方法
    MLIR中间表示和编译器框架
    Non-Maximum Suppression,NMS非极大值抑制
    华为计算平台MDC810发布量产
  • 原文地址:https://www.cnblogs.com/mobileliker/p/3167165.html
Copyright © 2020-2023  润新知