题目
二进制手表顶部有 4 个 LED 代表 小时(0-11),底部的 6 个 LED 代表 分钟(0-59)。每个 LED 代表一个 0 或 1,最低位在右侧。
例如,下面的二进制手表读取 “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
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/binary-watch
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
思路
思路比较直接,就是枚举出这个二进制数的每一位,然后分别判定是否符合时间单位的标准,如果是的话就保存下来输出即可,主要还是要学习二进制位运算的相关操作。
C++代码
class Solution {
public:
vector<string> readBinaryWatch(int num) {
vector<string> res;
char str[10];
for(int i=0;i<1<<10;i++)//枚举每一位
{
int s=0;
for(int j=0;j<10;j++)
{
if(i>>j & 1)//如果i的第j位是1
s++;
}
if(s==num)
{
int a=i>>6, b=i&63;//63=各个位均为1,a取了i的小时(最高的四位)
if(a<12 && b<60)
{
sprintf(str, "%d:%02d", a, b);
res.push_back(str);
}
}
}
return res;
}
};