当前位置: 首页 > article >正文

力扣每日一题 3211. 生成不含相邻零的二进制字符串

给你一个正整数 n

如果一个二进制字符串 x 的所有长度为 2 的子字符串中包含 至少 一个 "1",则称 x 是一个 有效 字符串。

返回所有长度为 n 的 有效 字符串,可以以任意顺序排列。

只要看懂了题目意思,这个题目就无脑暴力就可以了。

第一种方法:用递归,只要考虑根据前面填的数字,后面可以填哪些数字就可以了。

题目要求的就是二进制串没有连续的0出现。

我们可以直接枚举字符串的位置 i 填 1 还是 0:

如果前一个位置是0,那这个位置自然只能是1.

如果前一个位置是1,那这个位置不管是0还是1都可以。

枚举从i=1开始,到 i=n 结束把字符串填入数组即可。

class Solution {
public:
    void dfs(string s, int len)
    {
        if (len == 0)
        {
            ans.push_back(s);
            return;
        }
        if (s[s.length()-1]=='0') dfs(s+"1", len-1);
        else
        {
            dfs(s+"0", len-1);
            dfs(s+"1", len-1);
        }
    }
    vector<string> validStrings(int n) {
        ans.clear();
        str="";
        nlen = n;
        dfs("0", n-1);
        dfs("1", n-1);
        return ans;
    }
private:
    string str;
    vector<string> ans;
    int nlen;
};

第二种方法:直接枚举所有二进制长度为n的整数,判断是否满足条件,满足就把数字的二进制填进数组即可。

最容易想到的检查方法就是写出它的二进制,然后遍历找有没有连续的0.

不过其实还有种更快的方法检查,那就是位运算。怎么算呢?我们知道 x & (x >> 1) 的结果可以判断x是否有连续的1,那么我们只要稍微改一下,把x取反,就可以判断有没有连续的0了。

那怎么取反呢?

创建一个低 n 位全为 1 的二进制数 mask = (1 << n) - 1。
计算 x ^ mask,由于 0 和 1 异或后变成了 1,1 和 1 异或后变成了 0,所以 x 的低 n 位都取反了。

class Solution {
public:
    vector<string> validStrings(int n) {
        vector<string> ans;
        int mask = (1 << n) - 1;
        for (int i = 0; i < (1 << n); i++) 
        {
            int x = mask ^ i;
            if (!(x >> 1 & x)) 
            {
                ans.push_back(bitset<18>(x^mask).to_string().substr(18 - n));
            }
        }
        return ans;
    }
private:
    string str;
    vector<string> ans;
    int nlen;
};


http://www.kler.cn/a/378447.html

相关文章:

  • 【玩转全栈】----Django制作部门管理页面
  • SpringBoot项目中的异常处理
  • 学生管理系统C++版(简单版)详解
  • LAYA3.0 组件装饰器说明
  • FPGA 开发工作需求明确:关键要点与实践方法
  • linux下springboot项目nohup日志或tomcat日志切割处理方案
  • 使用Conda环境为Jupyter添加内核
  • [HTML]-基础标记:列表/标题/引用/表格/嵌入网页/图片/视频等
  • 力扣题目解析--罗马数字转整型
  • 一次明白——Vue.js组件开发!
  • Kubernetes运行大数据组件-运行spark
  • element plus中修改el-table的样式
  • JAVA语言多态和动态语言实现原理
  • 深度学习:反向传播算法简介
  • 一体化运维监控管理平台详解:构建高效运维体系
  • 如何通过OpenAI Gym学习强化学习
  • 乡村景区一体化系统(门票,餐饮,便利店,果园,娱乐,停车收费
  • 两个壁面之间夹一个圆柱形杆的温度分布
  • LeetCode 684.冗余连接:拓扑排序+哈希表(O(n)) 或 并查集(O(nlog n)-O(nα(n)))
  • 使用GetX实现GetPage中间件
  • WordPress在windows下安装
  • 【Git】从 GitHub 仓库中移除误提交的 IntelliJ IDEA 配置文件夹 .idea 并将其添加到 .gitignore 文件中
  • MyBatis-Plus快速入门:从安装到第一个Demo
  • React Native 0.76 重大更新:新架构全面启用
  • 基于Python的自然语言处理系列(47):DistilBERT:更小、更快、更省、更轻的BERT版本
  • C++编程法则365天一天一条(344)理解std::optional的设计初衷