Day 48 401. 二进制手表

401. 二进制手表

题目

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
二进制手表顶部有 4 个 LED 代表 小时(0-11),底部的 6 个 LED 代表 分钟(0-59)。

每个 LED 代表一个 01,最低位在右侧。

例如,下面的二进制手表读取 "3:25"

给你一个整数 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

题目思路

  • 1、使用打表的方法可能更好
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
class Solution {
public:
int count1(int n)
{
int k = 0;
while(n != 0)
{
n = n & (n - 1);
k++;
}
return k;
}

vector<string> readBinaryWatch(int turnedOn) {
vector<string> ans;
for (int i = 0; i < 12; i++)
{
for (int j = 0; j < 60; j++)
{
if (count1(i) + count1(j) == turnedOn)
{
ans.push_back(to_string(i)+":"+
(j < 10 ? "0"+to_string(j) : to_string(j)));
}
}
}
return ans;
}

};

复杂度

  • 时间复杂度:O(1)

  • 空间复杂度:O(1)


Day 48 401. 二进制手表
https://chaggle.github.io/2021/10/27/Leetcode/91-day/day-48/
作者
chaggle
发布于
2021年10月27日
许可协议