class Solution {
public:
vector<string> readBinaryWatch(int turnedOn) {
}
};
401. 二进制手表
二进制手表顶部有 4 个 LED 代表 小时(0-11),底部的 6 个 LED 代表 分钟(0-59)。每个 LED 代表一个 0 或 1,最低位在右侧。
"3:25"
。(图源:WikiMedia - Binary clock samui moon.jpg ,许可协议:Attribution-ShareAlike 3.0 Unported (CC BY-SA 3.0) )
给你一个整数 turnedOn
,表示当前亮着的 LED 的数量,返回二进制手表可以表示的所有可能时间。你可以 按任意顺序 返回答案。
小时不会以零开头:
"01:00"
是无效的时间,正确的写法应该是 "1:00"
。分钟必须由两位数组成,可能会以零开头:
"10:2"
是无效的时间,正确的写法应该是 "10:02"
。
示例 1:
输入:turnedOn = 1 输出:["0:01","0:02","0:04","0:08","0:16","0:32","1:00","2:00","4:00","8:00"]
示例 2:
输入:turnedOn = 9 输出:[]
提示:
0 <= turnedOn <= 10
原站题解
python3 解法, 执行用时: 40 ms, 内存消耗: 15.1 MB, 提交时间: 2022-05-24 11:25:28
class Solution: def readBinaryWatch(self, turnedOn: int) -> List[str]: ans = [] for i in range(1024): h, m = i >> 6, i & 0x3f if h < 12 and m < 60 and bin(i).count("1") == turnedOn: ans.append(f"{h}:{m:02d}") return ans
python3 解法, 执行用时: 48 ms, 内存消耗: 14.9 MB, 提交时间: 2022-05-24 11:19:02
class Solution: def readBinaryWatch(self, turnedOn: int) -> List[str]: ans = [] for h in range(12): for m in range(60): if bin(h).count("1") + bin(m).count("1") == turnedOn: ans.append(f"{h}:{m:02d}") return ans