回文时间

版权声明:禁止转载,翻版必究 https://blog.csdn.net/qq_41341757/article/details/83475111

回文时间
Time Limit: 1000 ms Memory Limit: 65536 KiB
Submit Statistic
Problem Description

HH 每天都会熬夜写代码,然后很晚才睡觉,但是每天早晨六点多必须要刷卡出宿舍,这就导致了必须在某些课上睡一会才能保证充沛的体力,当然某些重要的课是不能睡掉的,而某些课是可以睡的,比如《中国传统文化》,但是睡觉是不能被老师发现的,否则…他会以让你重修两年来威胁你。已知老师会在电子表上显示的时间为回文(例如:15:51)的时候来检查有没有人在睡觉,所以必须要在那个时间之前醒来。现在,给出 HH 开始睡觉的时间,你要帮她计算出下一个回文时间。
Input

输入包含多组测试数据,对于每组测试数据:
输入只有一行为一个字符串,字符串格式为"HH:MM",HH 和 MM 都为两位数字(00 ≤ HH ≤ 23, 00 ≤ MM ≤ 59)。
Output

对于每组测试数据,输出只有一行为下一个回文时间。
Sample Input

12:21
23:59
Sample Output

13:31
00:00

解析:
输入时间的分钟和小时,然后从分钟开始增加,如果分钟增加到60,则小时加一,分钟归0
,同时如果递增导致小时达到24,则小时归零。如果小时对10取余等于分钟除以10,并且
分钟对10取余,等于小时除以10,则找到,输出后,退出循环。

代码实现:

import java.util.Scanner;
public class Main
{
	public static void main(String[] args)
	{
		Scanner reader =new Scanner(System.in);
		while(reader.hasNext())
		{
			String string=reader.next();
			 String [] str=string.split(":");
			 int h=Integer.parseInt(str[0]);
			 int m=Integer.parseInt(str[1]);
			 Time time=new Time(h,m);
			 time.next();
		}
		reader.close();
	}
}
class Time
{
	int h;
	int m;
	public Time(int h,int m)
	{
		this.h=h;
		this.m=m;	
	}
	public void next()
	{
		for(m++; ;m++)
		{
			if(m==60)
			{
				h++;
				m=0;
				if(h==24)
				{
					h=0;
				}
			}
			if(h/10==m%10&&m/10==h%10)
			{
				System.out.printf("%02d:%02d\n",h,m);
				break;
			}
		}
	}
	
}

猜你喜欢

转载自blog.csdn.net/qq_41341757/article/details/83475111