SDUT-oj 时间日期格式转换(详解)

时间日期格式转换

Time Limit: 1000MS  Memory Limit: 65536KB
Problem Description
而北美所用的日期格式则为“月月/日日/年年年年”或”mm/dd /yyyy”,如将“2010/11/20”改成这种格式,对应的则是”11/20/2010”。对于时间的格式,则常有12小时制和24小时制
12小时制的表示方法是”05:30:00pm”。注意12:00:00pm表示中午12点,而12:00:00am 表示凌晨12点。
 第一行为一个整数T(T<=20),代表总共需要转换的时间日期字符串的数目。
<span 18px;="" \"="" style="box-sizing: border-box;">接下来的总共T行,每行都是一个需要转换的时间日期字符串。
Output
 分行输出转换之后的结果
Example Input
2
2010/11/20-12:12:12
1970/01/01-00:01:01
Example Output
11/20/2010-12:12:12pm
01/01/1970-12:01:01am
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Locale;
import java.util.Scanner;

public class Main {
	public static void main(String[] args) throws ParseException {
		Scanner p = new Scanner(System.in);
		int t = p.nextInt() ; 
		for(int i=0;i<t;i++){
			String time = p.next() ; 
			//yyyy/MM/dd - HH:mm:ss 为 24小时制 ; 
			//yyyy/MM/dd - hh:mm:ss 为12小时制 ; 
			SimpleDateFormat p1 = new SimpleDateFormat("yyyy/MM/dd-HH:mm:ss"); //以这个格式进行解析时间time ; 
			Date day = p1.parse(time);
			SimpleDateFormat p2 = new SimpleDateFormat("MM/dd/yyyy-hh:mm:ssa",new Locale("US")); //以这个格式重新生成时间 ;
			//"MM/dd/yyyy-hh:mm:ssa" 最后的那个a的意思是: a  Am/pm 标记  Text  PM ,a就代表am和pm  (jdk中SimpleDateFormat中的解释)
			//new Locale("US") 加上 输出 am,pm. 不加上 输出 上午,下午.(这个就是语言环境).
			//new Locale("US")的意思是:生成时间格式的环境.   "US" 的意思是: 时间环境是 美国US时间 .  也就是在 时间最后加 am,pm .
			String time1 = p2.format(day);
			time1 = time1.toLowerCase(); //将字符串中的字母转换成小写的.
			System.out.println(time1);
		}
	}
}


SDUT-OJ(Software Development University of Tsinghua Online Judge)是一个在线编程平台,提供给清华大学软件学院的学生和爱好者练习和解决算法问题的环境,其中包括各种计算机科学题目,包括数据结构、算法、图形等。对于"最小生成树"(Minimum Spanning Tree, MST)问题,它是图论中的经典问题,目标是从一个加权无向图中找到一棵包含所有顶点的树,使得树的所有边的权重之和最小。 在C语言中,最常见的是使用Prim算法或Kruskal算法来求解最小生成树。Prim算法从一个顶点开始,逐步添加与当前生成树相连且权重最小的边,直到所有顶点都被包含;而Kruskal算法则是从小到大对所有边排序,每次选取没有形成环的新边加入到树中。 如果你想了解如何用C语言实现这些算法,这里简单概括一下: - 通常使用优先队列(堆)来存储边和它们的权重,以便快速查找最小值。 - 从任意一个顶点开始,遍历与其相邻的边,若新边不形成环,就更新树,并将新边加入优先队列。 - Kruskal算法: - 先将所有的边按照权重升序排序。 - 创建一个空的最小生成树,然后依次取出排序后的边,如果这条边连接的两个顶点不在同一个连通分量,则将其添加到树中。 如果你需要更详细的代码示例,或者有具体的问题想了解(比如如何处理环、如何实现优先队列等),请告诉我,我会为你提供相应的帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值