二进制枚举--二进制手表
Posted C_YCBX Py_YYDS
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二进制枚举--二进制手表相关的知识,希望对你有一定的参考价值。
题目
题目解析
根据二进制的特性通过0101这种序列来表示灯是否亮,由于时钟范围是0~11对应二进制
0000\\0001\\0010\\0011\\0100\\0101\\0110\\0111\\1000\\1001\\1010\\1011
而对分钟的范围是0~59,只是此题需要转为二进制判断1的个数–得到灯亮的个数。
枚举时分
class Solution {
public:
vector<string> readBinaryWatch(int turnedOn) {
vector<string> ans;
for (int h = 0; h < 12; ++h) {
for (int m = 0; m < 60; ++m) {
//当亮灯的个数为给定值,则得到了一个答案
if (__builtin_popcount(h) + __builtin_popcount(m) == turnedOn) {
ans.push_back(to_string(h) + ":" + (m < 10 ? "0" : "") + to_string(m));
}
}
}
return ans;
}
};
位运算取位枚举
枚举10个二进制位,一直到 2 10 − 1 2^{10}-1 210−1,然后通过取高四位和低六位得到h和m。
class Solution {
public:
vector<string> readBinaryWatch(int turnedOn) {
vector<string> ans;
for (int i = 0; i < 1024; ++i) {
int h = i >> 6, m = i & 63; // 用位运算取出高 4 位和低 6 位
if (h < 12 && m < 60 && __builtin_popcount(i) == turnedOn) {
ans.push_back(to_string(h) + ":" + (m < 10 ? "0" : "") + to_string(m));
}
}
return ans;
}
};
以上是关于二进制枚举--二进制手表的主要内容,如果未能解决你的问题,请参考以下文章