“顶嵌杯”--初赛第4题分析
来源:互联网 发布:淘宝客链接转换器 编辑:程序博客网 时间:2024/05/29 16:42
时间日期格式转换
世界各地有多种格式来表示日期和时间。对于日期的常用格式,在中国常采用格式的是“年年年年/月月/日日”或写为英语缩略表示的”yyyy/mm/dd”,此次编程大赛的启动日期“2009/11/07”就是符合这种格式的一个日期,而北美所用的日期格式则为“月月/日日/年年年年”或”mm/dd/yyyy”,如将“2009/11/07”改成这种格式,对应的则是”11/07/2009”。对于时间的格式,则常有12小时制和24小时制的表示方法,24小时制用0-24来表示一天中的24小时,而12小时制只采用1-12表示小时,再加上am/pm来表示上午或下午,比如”17:30:00”是采用24小时制来表示时间,而对应的12小时制的表示方法是”05:30:00pm”。注意12:00:00pm表示中午12点,而12:00:00am表示凌晨12点。
对于给定的采用”yyyy/mm/dd”加24小时制(用短横线”-”连接)来表示日期和时间的字符串,请编程实现将其转换成”mm/dd/yyyy”加12小时制格式的字符串。
输入:
第一行为一个整数T(T<=10),代表总共需要转换的时间日期字符串的数目。
接下来的总共T行,每行都是一个需要转换的时间日期字符串。
输出:
分行输出转换之后的结果
样例输入:
2
2009/11/07-12:12:12
1970/01/01-00:01:01
样例输出:
11/07/2009-12:12:12pm
01/01/1970-12:01:01am
提示:
注意中午和凌晨时间的特殊表示
考察重点:字符串格式转化
参考代码:
#include <stdio.h>
#define LENGTH 22
#define MAX 10
int main()
{
int n,i,year,month,date,hour,min,sec;
char *f[MAX];
char end='/0';
char c;
scanf("%d",&n);
for(i=0;i<n;i++)
{
f[i]=(char *)malloc(LENGTH);
scanf("%s",f[i]);
sscanf(f[i],"%d/%d/%d-%d:%d:%d",&year,&month,&date,&hour,&min,&sec);
if(hour>=12&&hour<24)
{
if(hour!=12)
hour-=12;
c='p';
}
else
{
if(hour==0)
hour+=12;
c='a';
}
sprintf(f[i],"%02d/%02d/%d-%02d:%02d:%02d%cm%c",month,date,year,hour,min,sec,c,end);
}
for(i=0;i<n;i++)
{
printf("%s/n",f[i]);
free(f[i]);
}
return 0;
}
文章来源:http://top-e.org/student/html/510.html
- “顶嵌杯”--初赛第4题分析
- “顶嵌杯”--初赛第1题分析
- “顶嵌杯”--初赛第2题分析
- “顶嵌杯”--初赛第3题分析
- “顶嵌杯”--初赛第5题分析
- NOIP2005初赛阅读程序第4题
- 2008年百度之星程序设计大赛初赛第2场 第4题 圆面覆盖 解法
- 2008年百度之星程序设计大赛初赛第1场 第4题 公平数 解法
- 2012百度之星初赛第2场c题
- 百度之星初赛A第5题 BD String
- 微软编程之美2013全国挑战赛 初赛第1场 第2题
- 顶嵌杯(初赛)
- 2005年百度之星程序设计大赛初赛试题与解答 第1题
- 2012百度之星初赛第2场:A题试题及参考答案
- Hdu 4500 (2013年 腾讯 马拉松 初赛 第0场 第一题 )
- 百度之星初赛第二轮第一题超时代码(可能还有错误)
- 科赛平台--2017中国网络安全技术对抗赛(初赛第14名分享)-第一题
- NOIP初赛准备:第6课时
- 20100114
- 进步一点点
- “顶嵌杯”--初赛第1题分析
- “顶嵌杯”--初赛第2题分析
- “顶嵌杯”--初赛第3题分析
- “顶嵌杯”--初赛第4题分析
- “顶嵌杯”--初赛第5题分析
- 大二的期末考试
- 2010年1月14日
- 郁闷
- 博客园开通
- 系统程序员成长计划-组合的威力(三)
- Linux 进程管理剖析
- 【Silverlight】Bing Maps系列文章目录