POJ2351 ZOJ1916 UVA10371 Time Zones时区计算

Posted tigerisland45

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了POJ2351 ZOJ1916 UVA10371 Time Zones时区计算相关的知识,希望对你有一定的参考价值。

Time Zones
Time Limit: 1000MS Memory Limit: 65536K
Total Submissions: 2613 Accepted: 747

Description

Prior to the late nineteenth century, time keeping was a purely local phenomenon. Each town would set their clocks to noon when the sun reached its zenith each day. A clockmaker or town clock would be the "official" time and the citizens would set their pocket watches and clocks to the time of the town - enterprising citizens would offer their services as mobile clock setters, carrying a watch with the accurate time to adjust the clocks in customer‘s homes on a weekly basis. Travel between cities meant having to change one‘s pocket watch upon arrival.
However, once railroads began to operate and move people rapidly across great distances, time became much more critical. In the early years of the railroads, the schedules were very confusing because each stop was based on a different local time. The standardization of time was essential to efficient operation of railroads.

In 1878, Canadian Sir Sanford Fleming proposed the system of worldwide time zones that we use today. He recommended that the world be divided into twenty-four time zones, each spaced 15 degrees of longitude apart. Since the earth rotates once every 24 hours and there are 360 degrees of longitude, each hour the earth rotates one-twenty-fourth of a circle or 15° of longitude. Sir Fleming‘s time zones were heralded as a brilliant solution to a chaotic problem worldwide.

United States railroad companies began utilizing Fleming‘s standard time zones on November 18, 1883. In 1884 an International Prime Meridian Conference was held in Washington D.C. to standardize time and select the Prime Meridian. The conference selected the longitude of Greenwich, England as zero degrees longitude and established the 24 time zones based on the Prime Meridian. Although the time zones had been established, not all countries switched immediately. Though most U.S. states began to adhere to the Pacific, Mountain, Central, and Eastern time zones by 1895, Congress didn‘t make the use of these time zones mandatory until the Standard Time Act of 1918.

Today, many countries operate on variations of the time zones proposed by Sir Fleming. All of China (which should span five time zones) uses a single time zone - eight hours ahead of Coordinated Universal Time (known by the abbreviation UTC - based on the time zone running through Greenwich at 0° longitude). Russia adheres to its designated time zones although the entire country is on permanent Daylight Saving Time and is an hour ahead of their actual zones. Australia uses three time zones - its central time zone is a half-hour ahead of its designated time zone. Several countries in the Middle East and South Asia also utilize half-hour time zones.

Since time zones are based on segments of longitude and lines of longitude narrow at the poles, scientists working at the North and South Poles simply use UTC time. Otherwise, Antarctica would be divided into 24 very thin time zones!

Time zones have recently been given standard capital-letter abbreviations as follows:

UTC Coordinated Universal Time
GMT Greenwich Mean Time, defined as UTC
BST British Summer Time, defined as UTC+1 hour
IST Irish Summer Time, defined as UTC+1 hour
WET Western Europe Time, defined as UTC
WEST Western Europe Summer Time, defined as UTC+1 hour
CET Central Europe Time, defined as UTC+1
CEST Central Europe Summer Time, defined as UTC+2
EET Eastern Europe Time, defined as UTC+2
EEST Eastern Europe Summer Time, defined as UTC+3
MSK Moscow Time, defined as UTC+3
MSD Moscow Summer Time, defined as UTC+4
AST Atlantic Standard Time, defined as UTC-4 hours
ADT Atlantic Daylight Time, defined as UTC-3 hours
NST Newfoundland Standard Time, defined as UTC-3.5 hours
NDT Newfoundland Daylight Time, defined as UTC-2.5 hours
EST Eastern Standard Time, defined as UTC-5 hours
EDT Eastern Daylight Saving Time, defined as UTC-4 hours
CST Central Standard Time, defined as UTC-6 hours
CDT Central Daylight Saving Time, defined as UTC-5 hours
MST Mountain Standard Time, defined as UTC-7 hours
MDT Mountain Daylight Saving Time, defined as UTC-6 hours
PST Pacific Standard Time, defined as UTC-8 hours
PDT Pacific Daylight Saving Time, defined as UTC-7 hours
HST Hawaiian Standard Time, defined as UTC-10 hours
AKST Alaska Standard Time, defined as UTC-9 hours
AKDT Alaska Standard Daylight Saving Time, defined as UTC-8 hours
AEST Australian Eastern Standard Time, defined as UTC+10 hours
AEDT Australian Eastern Daylight Time, defined as UTC+11 hours
ACST Australian Central Standard Time, defined as UTC+9.5 hours
ACDT Australian Central Daylight Time, defined as UTC+10.5 hours
AWST Australian Western Standard Time, defined as UTC+8 hours

Given the current time in one time zone, you are to compute what time it is in another time zone.

Input

The first line of input contains N, the number of test cases. For each case a line is given with a time, and 2 time zone abbreviations. Time is given in standard a.m./p.m. format with midnight denoted "midnight" and noon denoted "noon" (12:00 a.m. and 12:00 p.m. are oxymorons).

Output

For each case, assuming the given time is the current time in the first time zone, give the current time in the second time zone.

Sample Input

4
noon HST CEST
11:29 a.m. EST GMT
6:01 p.m. CST UTC
12:40 p.m. ADT MSK

Sample Output

midnight
4:29 p.m.
12:01 a.m.
6:40 p.m.

Source

Waterloo local 2002.09.28

问题链接POJ2351 ZOJ1916 UVA10371 Time Zones
问题简述:(略)
问题分析
????这是一个时区计算问题,只能算是一个水题。程序逻辑上要处理得简洁才是关键。
程序说明:(略)
参考链接:(略)
题记:(略)

AC的C语言程序如下:

/* POJ2351 ZOJ1916 UVA10371 Time Zones */

#include <stdio.h>
#include <string.h>

char *zone[]={"UTC","GMT","BST","IST","WET","WEST","CET","CEST","EET","EEST","MSK"
             ,"MSD","AST","ADT","NST","NDT","EST","EDT","CST","CDT","MST","MDT","PST"
             ,"PDT","HST","AKST","AKDT","AEST","AEDT","ACST","ACDT","AWST"};
float time[]={0,0,1,1,0,1,1,2,2,3,3,4,-4,-3,-3.5,-2.5,-5,-4,-6,-5,-7,-6,-8,-7,-10,-9,-8,10,11,9.5,10.5,8};

int diff(char *zone1, char *zone2)
{
    int i, j;
    for(i = 0; strcmp(zone[i], zone1); i++);
    for(j = 0; strcmp(zone[j], zone2); j++);
    return (int)((time[i] - time[j]) * 60);
}

int main(void)
{
    int t;
    scanf("%d", &t);
    while(t--) {
        char buf[9];
        int hours, minutes;

        scanf("%s", buf);
        if(buf[0] == 'n')              /* noon */
            hours = 12, minutes = 0;
        else if(buf[0] == 'm')     /* midnight */
            hours = 0, minutes = 0;
        else {
            sscanf(buf, "%d:%d", &hours, &minutes);
            hours %= 12;
            scanf("%s", buf);      /* a.m. or p.m. */
            if(buf[0] == 'p')
                hours += 12;
        }

        char tz1[5], tz2[5];
        scanf("%s%s", tz1, tz2);
        int newtime = hours * 60 + minutes + diff(tz2, tz1);
        if(newtime < 0) newtime += 1440;
        newtime %= 1440;

        if(newtime == 0)
            printf("midnight
");
        else if(newtime == 720)
            printf("noon
");
        else {
            hours = newtime / 60;
            minutes = newtime % 60;
            if(hours == 0)
                printf("12:%02d a.m.
", minutes);
            else if(hours < 12)
                printf("%d:%02d a.m.
", hours, minutes);
            else if(hours == 12)
                printf("12:%02d p.m.
", minutes);
            else
                printf("%d:%02d p.m.
", hours % 12, minutes);
        }
    }

    return 0;
}

以上是关于POJ2351 ZOJ1916 UVA10371 Time Zones时区计算的主要内容,如果未能解决你的问题,请参考以下文章

UVA542 POJ2261 ZOJ1950 France ‘98概率

UVA10670 POJ1907 ZOJ2372 Work Reduction贪心

UVA10081 POJ2537 ZOJ1883 Tight WordsDP

UVA10277 POJ2646 ZOJ1856 Boastin‘ Red Socks数学

POJ2689 ZOJ1842 UVA10140 Prime Distance筛选法

UVA10202 POJ2466 ZOJ1895 Pairsumonious Numbers算术计算