LeetCode 401. Binary Watch

简介: 二进制手表顶部有 4 个 LED 代表小时(0-11),底部的 6 个 LED 代表分钟(0-59)。每个 LED 代表一个 0 或 1,最低位在右侧。

v2-1cc3d18557d7b727d95658dbffa5e2c1_1440w.jpg

Description



A binary watch has 4 LEDs on the top which represent the hours (0-11), and the 6 LEDs on the bottom represent the minutes (0-59).


Each LED represents a zero or one, with the least significant bit on the right.

For example, the above binary watch reads "3:25".


Given a non-negative integer n which represents the number of LEDs that are currently on, return all possible times the watch could represent.


Example:


Input: n = 1
Return: ["1:00", "2:00", "4:00", "8:00", "0:01", "0:02", "0:04", "0:08", "0:16", "0:32"]


Note:

The order of output does not matter.

The hour must not contain a leading zero, for example "01:00" is not valid, it should be "1:00".


The minute must be consist of two digits and may contain a leading zero, for example "10:2" is not valid, it should be "10:02".


描述



二进制手表顶部有 4 个 LED 代表小时(0-11),底部的 6 个 LED 代表分钟(0-59)。

每个 LED 代表一个 0 或 1,最低位在右侧。


例如,上面的二进制手表读取 “3:25”。

给定一个非负整数 n 代表当前 LED 亮着的数量,返回所有可能的时间。

案例:


输入: n = 1
返回: ["1:00", "2:00", "4:00", "8:00", "0:01", "0:02", "0:04", "0:08", "0:16", "0:32"]


注意事项:


输出的顺序没有要求。

小时不会以零开头,比如 “01:00” 是不允许的,应为 “1:00”。

分钟必须由两位数组成,可能会以零开头,比如 “10:2” 是无效的,应为 “10:02”。


来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/binary-watch

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。


思路


  • 对每个位置编号 (范围是 [0,9],一共 10 个位置),形成键值对;键位编号,值表盘对应的时间。
  • 其中,对分钟用 range(0,6) 进行编号;小时用 range(6,10) 进行编号;
  • 对于输入 num,使用 Python 的 combinations 模块,从 list(range(10)) 中随机选取 num 个数字;然后以这些数字为键,拿到对应的小时和分钟数,构成当前时间;对于不符合要求的时间直接丢弃;


# -*- coding: utf-8 -*-
# @Author:             何睿
# @Create Date:        2019-09-03 22:35:31
# @Last Modified by:   何睿
# @Last Modified time: 2019-09-04 08:59:55
from typing import List
from itertools import combinations
class Solution:
    def readBinaryWatch(self, num: int) -> List[str]:
        minutes = {i: 2**i for i in range(6)}
        hours = {i: 2**(i - 6) for i in range(6, 10)}
        times = map(lambda x: self.__transfer(x, minutes, hours), combinations(list(range(10)), num))
        return filter(lambda x: x is not None, times)
    def __transfer(self, com, minutes, hours):
        minute = sum(map(lambda x: minutes.get(x, 0), com))
        hour = sum(map(lambda x: hours.get(x, 0), com))
        return "{}:{:02d}".format(hour, minute) if hour <= 11 and minute <= 59 else None

源代码文件在 这里


目录
相关文章
Leetcode Minimum Depth of Binary Tree (面试题推荐)
计算树的最小深度 很简单的一道题,只需要遍历一次树,到叶子节点的时候计算一下深度和当前最小深度比较,保存最小值就行。 我在这用了一个全局变量 mindepth。总感觉我这代码写的不够简练,求更精简的方法。
54 0
Leetcode Binary Tree Postorder Traversal(面试题推荐)
非递后续归遍历二叉树,肯定得用到栈。先序遍历很好写,但后续遍历就不是那么容易了。 只需要设置个指针pre,指向最后输出的那个节点就行了,只要判断cur指针指向的是上次输出节点的父节点,且cur无其他未遍历的节点,这个时候就把cur节点输出即可,然后更改pre。原理是要遍历当前节点,其所有子节点都必须遍历完,因为肯定是先左后右,所以只需一个指针保持前一次输出的结果即可。
58 0
Leetcode 236. Lowest Common Ancestor of a Binary Tree
根据LCA的定义,二叉树中最小公共祖先就是两个节点p和q最近的共同祖先节点,LCA的定义没什么好解释的,主要是这道题的解法。
47 0
LeetCode contest 190 5418. 二叉树中的伪回文路径 Pseudo-Palindromic Paths in a Binary Tree
LeetCode contest 190 5418. 二叉树中的伪回文路径 Pseudo-Palindromic Paths in a Binary Tree
LeetCode Contest 178-1367. 二叉树中的列表 Linked List in Binary Tree
LeetCode Contest 178-1367. 二叉树中的列表 Linked List in Binary Tree
|
存储 算法
LeetCode297. Serialize and Deserialize Binary Tree
序列化是将一个数据结构或者对象转换为连续的比特位的操作,进而可以将转换后的数据存储在一个文件或者内存中,同时也可以通过网络传输到另一个计算机环境,采取相反方式重构得到原数据。 请设计一个算法来实现二叉树的序列化与反序列化。这里不限定你的序列 / 反序列化算法执行逻辑,你只需要保证一个二叉树可以被序列化为一个字符串并且将这个字符串反序列化为原始的树结构。
52 0
LeetCode297. Serialize and Deserialize Binary Tree
|
算法 Python
LeetCode 108. 将有序数组转换为二叉搜索树 Convert Sorted Array to Binary Search Tree
LeetCode 108. 将有序数组转换为二叉搜索树 Convert Sorted Array to Binary Search Tree
LeetCode 102. 二叉树的层序遍历 Binary Tree Level Order Traversal
LeetCode 102. 二叉树的层序遍历 Binary Tree Level Order Traversal
LeetCode 104. 二叉树的最大深度 Maximum Depth of Binary Tree
LeetCode 104. 二叉树的最大深度 Maximum Depth of Binary Tree
|
4月前
|
Unix Shell Linux
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行
本文提供了几个Linux shell脚本编程问题的解决方案,包括转置文件内容、统计词频、验证有效电话号码和提取文件的第十行,每个问题都给出了至少一种实现方法。
LeetCode刷题 Shell编程四则 | 194. 转置文件 192. 统计词频 193. 有效电话号码 195. 第十行