[Swift]LeetCode1016. 子串能表示从 1 到 N 数字的二进制串 | Binary String With Substrings Representing 1 To N
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公众号:山青咏芝(shanqingyongzhi)
➤博客园地址:山青咏芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址: https://www.cnblogs.com/strengthen/p/10588057.html
➤如果链接不是山青咏芝的博客园地址,则可能是爬取作者的文章。
➤原文已修改更新!强烈建议点击原文地址阅读!支持作者!支持原创!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
Given a binary string S
(a string consisting only of '0' and '1's) and a positive integer N
, return true if and only if for every integer X from 1 to N, the binary representation of X is a substring of S.
Example 1:
Input: S = "0110", N = 3
Output: true
Example 2:
Input: S = "0110", N = 4
Output: false
Note:
1 <= S.length <= 1000
1 <= N <= 10^9
给定一个二进制字符串 S
(一个仅由若干 '0' 和 '1' 构成的字符串)和一个正整数 N
,如果对于从 1
到 N
的每个整数 X
,其二进制表示都是 S
的子串,就返回 true
,否则返回 false
。
示例 1:
输入:S = "0110", N = 3 输出:true
示例 2:
输入:S = "0110", N = 4 输出:false
提示:
1 <= S.length <= 1000
1 <= N <= 10^9
Runtime: 8 ms
Memory Usage: 20.4 MB
1 class Solution { 2 func queryString(_ S: String, _ N: Int) -> Bool { 3 if N > 2400 {return false} 4 for i in 1...N 5 { 6 var str:String = String() 7 var x:Int = i 8 while (x != 0) 9 { 10 str.append((x % 2 + 48).ASCII) 11 x /= 2 12 } 13 str = String(str.reversed()) 14 if !S.contains(str) {return false} 15 } 16 return true 17 } 18 } 19 20 //Int扩展 21 extension Int 22 { 23 //Int转Character,ASCII值(定义大写为字符值) 24 var ASCII:Character 25 { 26 get {return Character(UnicodeScalar(self)!)} 27 } 28 }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了