算法中等滑动窗口周赛最短且字典序最小的美丽子字符串
Hoshea Zhang答案中恰好有K个1,可以考虑用滑动窗口,如果窗口内的1个数超过k,或者窗口端点为0,则缩小窗口
题目
给你一个二进制字符串 s
和一个正整数 k
。
如果 s
的某个子字符串中 1
的个数恰好等于 k
,则称这个子字符串是一个 美丽子字符串 。
令 len
等于 最短 美丽子字符串的长度。
返回长度等于 len
且字典序 最小 的美丽子字符串。如果 s
中不含美丽子字符串,则返回一个 空 字符串。
对于相同长度的两个字符串 a
和 b
,如果在 a
和 b
出现不同的第一个位置上,a
中该位置上的字符严格大于 b
中的对应字符,则认为字符串 a
字典序 大于 字符串 b
。
- 例如,
"abcd"
的字典序大于 "abcc"
,因为两个字符串出现不同的第一个位置对应第四个字符,而 d
大于 c
。
示例 1:
1 2 3 4 5 6 7 8 9 10 11 12
| 输入:s = "100011001", k = 3 输出:"11001" 解释:示例中共有 7 个美丽子字符串: 1. 子字符串 "100011001" 。 2. 子字符串 "100011001" 。 3. 子字符串 "100011001" 。 4. 子字符串 "100011001" 。 5. 子字符串 "100011001" 。 6. 子字符串 "100011001" 。 7. 子字符串 "100011001" 。 最短美丽子字符串的长度是 5 。 长度为 5 且字典序最小的美丽子字符串是子字符串 "11001" 。
|
示例 2:
1 2 3 4 5 6 7 8
| 输入:s = "1011", k = 2 输出:"11" 解释:示例中共有 3 个美丽子字符串: 1. 子字符串 "1011" 。 2. 子字符串 "1011" 。 3. 子字符串 "1011" 。 最短美丽子字符串的长度是 2 。 长度为 2 且字典序最小的美丽子字符串是子字符串 "11" 。
|
示例 3:
1 2 3
| 输入:s = "000", k = 1 输出:"" 解释:示例中不存在美丽子字符串。
|
提示:
1 <= s.length <= 100
1 <= k <= s.length
解答
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
| class Solution { public: string shortestBeautifulSubstring(string s, int k) { string res = ""; if(count(s.begin(),s.end(),'1')<k){ return ""; } string ans = s; int cnt1 = 0,left = 0; for(int right = 0;right<s.size();right++){ cnt1+=s[right]-'0'; while(cnt1>k||s[left]=='0'){ cnt1-=s[left++]-'0'; } if(cnt1==k){ string t = s.substr(left,right-left+1); if(t.size()<ans.size()||(t.size()==ans.size()&&t<ans)){ ans = t; } } } return ans; } };
|