【每日一题Day203】LC1016子串能表示从 1 到 N 数字的二进制串 | 枚举 哈希表

简介: 【每日一题Day203】LC1016子串能表示从 1 到 N 数字的二进制串 | 枚举 哈希表

子串能表示从 1 到 N 数字的二进制串【LC1016】

给定一个二进制字符串 s 和一个正整数 n,如果对于 [1, n] 范围内的每个整数,其二进制表示都是 s子字符串 ,就返回true,否则返回 false

子字符串 是字符串中连续的字符序列。

把智齿了,今天稍微休息一下

正向+枚举
  • 思路
    枚举1至n的每一个数的二进制表示是否在s中出现,如果所有二进制表示都出现,那么返回true;如果有一个不出现,则返回false
  • 实现
class Solution {
    public boolean queryString(String s, int n) {
        for (int i = 1; i <= n; i++){
            if (s.indexOf(Integer.toBinaryString(i)) == -1){
                return false;
            }
        }
        return true;
    }
}

复杂度

  • 时间复杂度:O(min(m,n)mlogmin(m,n)),m为s的长度
  • 空间复杂度:O(logn)
逆向+哈希表
  • 思路枚举s的每一个子串(首字符不为0),如果其数值小于等于n,那么将其数值记录在哈希表中,如果最后哈希表中的个数等于n,那么返回true
  • 如何将子串转化为二进制数?
    设当前得到的二进制数为x,且下一个字符 s[j+1]c,那么将x那么将 x xx 更新为 (x << 1) | (c - '0')

实现

class Solution {
    public boolean queryString(String S, int n) {
        var seen = new HashSet<Integer>();
        var s = S.toCharArray();
        for (int i = 0, m = s.length; i < m; ++i) {
            int x = s[i] - '0';
            if (x == 0) continue; // 二进制数从 1 开始
            for (int j = i + 1; x <= n; j++) {
                seen.add(x);
                if (j == m) break;
                x = (x << 1) | (s[j] - '0'); // 子串 [i,j] 的二进制数
            }
        }
        return seen.size() == n;
    }
}
作者:灵茶山艾府
链接:https://leetcode.cn/problems/binary-string-with-substrings-representing-1-to-n/solutions/2265097/san-chong-suan-fa-cong-bao-li-dao-you-hu-nmtq/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

复杂度

  • 时间复杂度:O(mlogn),m为s的长度
  • 空间复杂度:O(min(mlogn,n)),哈希表所需要的空间
目录
相关文章
|
9月前
【每日一题Day370】LC318最大单词长度乘积 | 哈希表 位运算
【每日一题Day370】LC318最大单词长度乘积 | 哈希表 位运算
69 1
|
9月前
|
C++
c++:string相关的oj题(把字符串转换成整数、344.反转字符串、387. 字符串中的第一个唯一字符、917. 仅仅反转字母)
c++:string相关的oj题(把字符串转换成整数、344.反转字符串、387. 字符串中的第一个唯一字符、917. 仅仅反转字母)
88 0
|
9月前
|
C语言 C++
C语言利用ASCII码表统计字符串每个字符出现的次数
C语言利用ASCII码表统计字符串每个字符出现的次数
119 0
|
9月前
|
存储 编译器 Linux
标准库中的string类(中)+仅仅反转字母+字符串中的第一个唯一字符+字符串相加——“C++”“Leetcode每日一题”
标准库中的string类(中)+仅仅反转字母+字符串中的第一个唯一字符+字符串相加——“C++”“Leetcode每日一题”
|
9月前
【每日一题Day237】LC1375二进制字符串前缀一致的次数 | 技巧题
【每日一题Day237】LC1375二进制字符串前缀一致的次数 | 技巧题
62 1
|
9月前
leetcode-1784:检查二进制字符串字段
leetcode-1784:检查二进制字符串字段
43 0
|
9月前
【每日一题Day317】LC2605从两个数字数组里生成最小数字 | 哈希表
【每日一题Day317】LC2605从两个数字数组里生成最小数字 | 哈希表
47 0
|
索引
【LC简单】387. 字符串中的第一个唯一字符
【LC简单】387. 字符串中的第一个唯一字符
90 0
【LC简单】387. 字符串中的第一个唯一字符
|
机器学习/深度学习
【每日一题Day74】LC2351第一个出现两次的字母 | 哈希表 位运算
思路:使用哈希表统计出现的字母及其次数,当某个字母出现次数为2时立即返回
67 0