给你一个二进制字符串 s
,该字符串 不含前导零 。
如果 s
包含 零个或一个由连续的 '1'
组成的字段 ,返回 true
。否则,返回 false
。
示例 1:
输入:s = "1001"
输出:false
解释:由连续若干个 '1'
组成的字段数量为 2,返回 false
示例 2:
输入:s = "110" 输出:true
提示:
1 <= s.length <= 100
s[i]
为'0'
或'1'
s[0]
为'1'
方法一:0 后面不能有 1
注意到字符串
若字符串 false
。
若字符串 true
。
因此,只需要判断字符串
时间复杂度
class Solution:
def checkOnesSegment(self, s: str) -> bool:
return '01' not in s
class Solution {
public boolean checkOnesSegment(String s) {
return !s.contains("01");
}
}
class Solution {
public:
bool checkOnesSegment(string s) {
return s.find("01") == -1;
}
};
func checkOnesSegment(s string) bool {
return !strings.Contains(s, "01")
}
function checkOnesSegment(s: string): boolean {
let pre = s[0];
for (const c of s) {
if (pre !== c && c === '1') {
return false;
}
pre = c;
}
return true;
}
function checkOnesSegment(s: string): boolean {
return !s.includes('01');
}
impl Solution {
pub fn check_ones_segment(s: String) -> bool {
!s.contains("01")
}
}