LeetCode Next Closest Time
原题链接在这里:https://leetcode.com/problems/next-closest-time/
题目:
Given a time represented in the format "HH:MM", form the next closest time by reusing the current digits. There is no limit on how many times a digit can be reused.
You may assume the given input string is always valid. For example, "01:34", "12:09" are all valid. "1:34", "12:9" are all invalid.
Example 1:
Input: "19:34"
Output: "19:39"
Explanation: The next closest time choosing from digits 1, 9, 3, 4, is 19:39, which occurs 5 minutes later. It is not 19:33, because this occurs 23 hours and 59 minutes later.
Example 2:
Input: "23:59"
Output: "22:22"
Explanation: The next closest time choosing from digits 2, 3, 5, 9, is 22:22. It may be assumed that the returned time is next day's time since it is smaller than the input time numerically.
题解:
用当前time已经出现的四个数字,组成新的time. 找diff最小的新time.
First get integer hash value of current time.
Get all 4 digits of current time. Take 2 of them to construct hour, and the other 2 to construct minute.
Use new time hash value - current time hash value and maintain the minimum diff.
If minused result < 0, it is next day, add it with 24 * 60.
Time Complexity: O(1). 共有4^4种组合.
Space: O(1). size为4的HashSet.
AC Java:
 class Solution {
     public String nextClosestTime(String time) {
         Set<Integer> hs = new HashSet<>();
         for(int i = 0; i<time.length(); i++){
             char c = time.charAt(i);
             if(c != ':'){
                 hs.add(c-'0');
             }
         }
         int cur = Integer.valueOf(time.substring(0, 2)) * 60 + Integer.valueOf(time.substring(3, 5)); 
         int minDiff = 24*60;
         // res is initialized as time, in case "11:11". The expected result is "11: 11".
         String res = time;
         for(int h1 : hs){
             for(int h2 : hs){
                 if(h1*10 + h2 < 24){
                     for(int m1 : hs){
                         for(int m2 : hs){
                             if(m1*10 + m2 < 60){
                                 int can = (h1*10+h2) * 60 + m1*10+m2;
                                 int diff = can-cur;
                                 if(diff < 0){
                                     diff += 24*60;
                                 }
                                 // diff can't 0, otherwise, it would return itself
                                 if(diff>0 && diff<minDiff){
                                     minDiff = diff;
                                     res = ""+h1+h2+":"+m1+m2;
                                     System.out.println("m1: "+ m1 + " m2: " + m2);
                                 }
                             }
                         }
                     }
                 }
             }
         }
         return res;
     }
 }
LeetCode Next Closest Time的更多相关文章
- [LeetCode] 272. Closest Binary Search Tree Value II 最近的二叉搜索树的值 II
		Given a non-empty binary search tree and a target value, find k values in the BST that are closest t ... 
- [LeetCode] 3Sum Closest 最近三数之和
		Given an array S of n integers, find three integers in S such that the sum is closest to a given num ... 
- [LeetCode] Next Closest Time 下一个最近时间点
		Given a time represented in the format "HH:MM", form the next closest time by reusing the ... 
- [LeetCode] 272. Closest Binary Search Tree Value II 最近的二分搜索树的值之二
		Given a non-empty binary search tree and a target value, find k values in the BST that are closest t ... 
- [LeetCode] 270. Closest Binary Search Tree Value 最近的二叉搜索树的值
		Given a non-empty binary search tree and a target value, find the value in the BST that is closest t ... 
- Leetcode  3Sum Closest
		Given an array S of n integers, find three integers in S such that the sum is closest to a given num ... 
- Leetcode 270. Closest Binary Search Tree Value
		Given a non-empty binary search tree and a target value, find the value in the BST that is closest t ... 
- [LeetCode#272] Closest Binary Search Tree Value II
		Problem: Given a non-empty binary search tree and a target value, find k values in the BST that are ... 
- [leetcode]272. Closest Binary Search Tree Value II二叉搜索树中最近的值2
		Given a non-empty binary search tree and a target value, find k values in the BST that are closest t ... 
随机推荐
- sublime text3 破解, 中文乱码支持, 设置
			1. 激活 菜单: Help -> Enter License, 弹出对话框输入激活码确认(Use License):如下图:. 激活码: ----- BEGIN LICENSE ----- A ... 
- 自定义Log实现条件编译
			在项目pch中添加以下代码,其中DEBUG为Xcode项目自带的宏,存在时表示当前为调试状态,否则为发布状态.故当在发布状态时,通过自定义TestLog所使用的NSLog调试信息,都会被预编译替换为空 ... 
- iOS日常学习 - 让你的 Xcode8 继续使用插件
			本文转载,原文链接 随着 iOS10 的正式版即将发布,Xcode8 GM 也在发布会后放出,本文不会涉及到 Xcode8 有哪些更新,而是记录了如何让 Xcode8 继续支持 Plugin. 相信各 ... 
- fix LayerKit framework不能提交App Store
			- 问题: - 原因 x86_64, i386是ios模拟器用的architectures.发布时,不支持这两种.但是,默认编译出来的layerkit framework支持这两种编译器 - 解决办法 ... 
- Mac安装搭建sublimeText3开发Nodejs环境
			原文] [基本环境 安装Nodejs 这个直接就可以去官网下载就可以了.Nodejs官网 根据自己的PC系统类型选择对应的版本下载之后就可以了. 安装SublimeText3 这个也是直接去Subli ... 
- Spring Boot 热部署的实现 - 原创
			实现方式有两大种(其中包含3种): 一.基于springloaded 1.1)Maven启动方式 第一步:在pom.xml中的“plugin节点”里面添加如下依赖: <dependencies& ... 
- 转 : Java的版本特性与历史
			Java Versions, Features and History This article gives you a highlight of important features added i ... 
- scala学习手记33 - 使用trait进行装饰
			在上一节看到了scala的在实例一级的选择性混入就不得不感叹scala在语法上的扩展性.就通过这样一个特性scala简化了很多在java中的编程概念和设计模式. 比如说在java中常用的组合,以及装饰 ... 
- elsevier 与 springer 投稿区别
			http://emuch.net/bbs/viewthread.php?tid=5369913 
- css tips —— 可见性对图片加载的影响
			如果是<img />标签,无论是display: none:还是visibility: hidden;都会加载图片: 但是如果是背景图片即background-image: url(xxx ... 
