二进制枚举--二进制手表

Posted C_YCBX Py_YYDS

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二进制枚举--二进制手表相关的知识,希望对你有一定的参考价值。

题目

在这里插入图片描述
提交OJ

题目解析

根据二进制的特性通过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 2101,然后通过取高四位和低六位得到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;
    }
};

以上是关于二进制枚举--二进制手表的主要内容,如果未能解决你的问题,请参考以下文章

二进制枚举--二进制手表

401. 二进制手表

LeetCode:二进制手表401

401. 二进制手表

《LeetCode之每日一题》:67.二进制手表

LeetCode 401. Binary Watch(二进制手表)