P1152 时区间时间的转换

题目描述

直到 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), 定义为 UTC
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 hour
CEST (Central Europe Summer Time), 定义为 UTC+2 hours
EET (Eastern Europe Time), 定义为 UTC+2 hours
EEST (Eastern Europe Summer Time), 定义为 UTC+3 hours
MSK (Moscow Time), 定义为 UTC+3 hours
MSD (Moscow Summer Time), 定义为 UTC+4 hours
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:1 a.m.

6:40 p.m.

#include<stdio.h>
#include<string.h>
double table(char*s){
	if(!strcmp(s,"UTC"))	return 0.0;
	if(!strcmp(s,"GMT"))	return 0.0;
	if(!strcmp(s,"BST"))	return 1.0;
	if(!strcmp(s,"IST"))	return 1.0;
	if(!strcmp(s,"WET"))	return 0.0;
	if(!strcmp(s,"WEST"))	return 1.0;
	if(!strcmp(s,"CET"))	return 1.0;
	if(!strcmp(s,"CEST"))	return 2.0;
	if(!strcmp(s,"EET"))	return 2.0;
	if(!strcmp(s,"EEST"))	return 3.0;
	if(!strcmp(s,"MSK"))	return 3.0;
	if(!strcmp(s,"MSD"))	return 4.0;
	if(!strcmp(s,"AST"))	return -4.0;
	if(!strcmp(s,"ADT"))	return -3.0;
	if(!strcmp(s,"NST"))	return -3.5;
	if(!strcmp(s,"NDT"))	return -2.5;
	if(!strcmp(s,"EST"))	return -5.0;
	if(!strcmp(s,"EDT"))	return -4.0;
	if(!strcmp(s,"CST"))	return -6.0;
	if(!strcmp(s,"CDT"))	return -5.0;
	if(!strcmp(s,"MST"))	return -7.0;
	if(!strcmp(s,"MDT"))	return -6.0;
	if(!strcmp(s,"PST"))	return -8.0;
	if(!strcmp(s,"PDT"))	return -7.0;
	if(!strcmp(s,"HST"))	return -10.0;
	if(!strcmp(s,"AKST"))	return -9.0;
	if(!strcmp(s,"AKDT"))	return -8.0;
	if(!strcmp(s,"AEST"))	return 10.0;
	if(!strcmp(s,"AEDT"))	return 11.0;
	if(!strcmp(s,"ACST"))	return 9.5;
	if(!strcmp(s,"ACDT"))	return 10.5;
	if(!strcmp(s,"AWST"))	return 8.0;
}
int main(){
	int n;
	scanf("%d",&n);
	while(n--){
		char s[11],a[5],b[5];
		int t,i;
		scanf("%s",s);
		if(s[0]=='n')
			t=12*60;
		else if(s[0]=='m')
			t=24*60;
		else{
			if(s[1]==':')
				t=(s[0]-'0')*60+(s[2]-'0')*10+(s[3]-'0');
			else
				t=((s[0]-'0')*10+(s[1]-'0'))*60
					+(s[3]-'0')*10+(s[4]-'0');
			if(t/60==12)t-=12*60;
			scanf("%s",s);
			if(s[0]=='p')t+=12*60;
		}
		scanf("%s%s",a,b);
		t+=(int)((table(b)-table(a))*60);
		if(t<=0)t+=24*60;
		if(t>24*60)t-=24*60;

		if(t==12*60)
			printf("noon\n");
		else if(t==24*60)
			printf("midnight\n");
		else{
			// printf("*%d	%d\n",t/60,t%60);
			char ss[6];
			strcpy(ss,"a.m.");
			if(t>=12*60){
				t-=12*60;
				ss[0]='p';
			}
			if(t<60)
				t+=12*60;
			printf("%d:%d %s\n",t/60,t%60,ss);
		}
	}
	return 0;
}

 

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在MATLAB中,可以使用ARIMA模型进行时间序列预测。ARIMA模型是一种常用的时间序列模型,用于描述时间序列数据的趋势和周期性特征。ARIMA模型的参数包括p、d和q,分别代表自回归(AR)、差分(I)和移动平均(MA)的阶数。根据您的时间序列数据的特点,可以选择不同的参数来创建ARIMA模型\[2\]。 在使用MATLAB进行ARIMA模型预测,首先需要准备数据。可以使用fillmissing函数来处理缺失值,然后导入时间序列变量。接下来,可以进行探索性数据分析,包括将数据转换为固定数据、执行一阶差分、执行增强的Dickey-Fuller测试和绘制自相关图\[3\]。 最后,可以将ARIMA模型拟合到数据中,使用arima函数创建一个ARIMA(p,d,q)模型。根据您的数据特点,可以选择合适的参数值来创建模型。例如,可以使用Mdl = arima(p,d,q)来创建一个ARIMA模型\[2\]。 请注意,具体的参数选择和模型拟合过程可能需要根据您的数据和需求进行调整。建议参考MATLAB的文档和示例来了解更多关于ARIMA模型的使用方法。 #### 引用[.reference_title] - *1* [区间预测 | MATLAB实现ARIMA时间序列预测](https://blog.csdn.net/kjm13182345320/article/details/127100244)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [ARIMA时间序列预测MATLAB代码模板(无需调试)](https://blog.csdn.net/m0_62526778/article/details/128983299)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [序预测 | MATLAB实现ARIMA时间序列预测(GDP预测)](https://blog.csdn.net/kjm13182345320/article/details/127802341)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值