OpenJudge百炼-2966-时区转换-C语言-日期处理
来源:互联网 发布:知吾煮抗摔玻璃保鲜盒 编辑:程序博客网 时间:2024/05/16 10:21
描述:
直到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.
/*******************************************************文件名:百炼-2966**Copyright (c) 2015-2025 OrdinaryCrazy**创建人:OrdinaryCrazy**日期:20170810**描述:百炼2966参考答案**版本:1.0******************************************************/#include <stdio.h>#include <string.h>/*******************************************************问题的关键在于计算两个时区之间的时差,可以首先将时区与该时区和格林尼治时间的时差相对应,然后在计算任意两个时区之间的时差以起步地当天的00:00为基准********************************************************/char* zone[32] = {"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 tdif[32] = {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 main(){ int n; scanf("%d",&n); while(n--) { char time[9],timezonefrom[5],timezoneto[5]; int hours,minutes,i,j,newtime; scanf("%s",time); switch(time[0]) { case 'n' : hours = 12;minutes = 0;break; case 'm' : hours = 0;minutes = 0;break; default : sscanf(time,"%d:%d",&hours,&minutes); hours %= 12;//12:01 a.m.是凌晨00:01,12:01 p.m.是中午12:01,这里处理的是凌晨的情况 scanf("%s",time); if(time[0] == 'p') hours += 12; } scanf("%s%s",timezonefrom,timezoneto); for(i = 0;strcmp(zone[i],timezonefrom);i++); for(j = 0;strcmp(zone[j],timezoneto);j++); newtime = hours * 60 + minutes + (tdif[j] - tdif[i])*60; if(newtime < 0) newtime += 1440;//提前一天的情况 newtime %= 1440;//超过一天的情况 switch(newtime) { case 0 : printf("midnight\n");break; case 720 : printf("noon\n");break; default : hours = newtime / 60; minutes = newtime % 60; if(hours == 0) printf("12:%02d a.m.\n",minutes); else if(hours < 12) printf("%d:%02d a.m.\n",hours,minutes); else if(hours == 12) printf("12:%02d p.m.\n",minutes); else printf("%d:%02d p.m.\n",hours % 12,minutes); } } return 0;}
- OpenJudge百炼-2966-时区转换-C语言-日期处理
- OpenJudge百炼-2712-细菌繁殖-C语言-日期处理
- OpenJudge百炼-2964-日历问题-C语言-日期处理
- OpenJudge百炼-2965-玛雅历-C语言-日期处理
- OpenJudge百炼-2967-特殊日历计算-C语言-日期处理
- OpenJudge百炼-2974-487-3279-C语言-字符串处理
- OpenJudge百炼-2744-子串-C语言-字符串处理
- OpenJudge百炼-2820-古代密码-C语言-字符串处理
- OpenJudge百炼-2798-2进制化为16进制-C语言-数制转换
- OpenJudge百炼-2799-浮点数格式-C语言-字符串处理
- OpenJudge百炼-2819-W的密码-C语言-字符串处理
- OpenJudge百炼-1936-全在其中-C语言-字符串处理
- OpenJudge百炼-2950-摘花生-C语言
- OpenJudge百炼-2745-显示器-C语言-模拟
- OpenJudge百炼-1833-排列-C语言-模拟
- OpenJudge百炼-2706-麦森数-C语言-高精度计算
- OpenJudge百炼-2692-假币问题-C语言-枚举
- OpenJudge百炼-2811-熄灯问题-C语言-枚举
- vs2015数据驱动的单元测试
- [linux]grep 查看前后文
- 批量下载matplotlib.pyplot.subplots页面实例源码的python脚本
- 加密算法
- 用python实现机器学习算法(一)---DesicionTree
- OpenJudge百炼-2966-时区转换-C语言-日期处理
- hdu 6103 暴力枚举+贪心
- BS和CS的区别以及优缺点
- 【Android破解笔记】割绳子2内购
- Android 内存管理
- C++中智能指针的设计和使用
- 庆祝成为CSDN博客专家
- Unity自定义UI组件(十二) 条形图篇
- LeetCode 13. Roman to Integer -- 罗马数字转整数