提示
中等
1
相关企业
给你一个二进制字符串 s
和一个正整数 k
。
如果 s
的某个子字符串中 1
的个数恰好等于 k
,则称这个子字符串是一个 美丽子字符串 。
令 len
等于 最短 美丽子字符串的长度。
返回长度等于 len
且字典序 最小 的美丽子字符串。如果 s
中不含美丽子字符串,则返回一个 空 字符串。
对于相同长度的两个字符串 a
和 b
,如果在 a
和 b
出现不同的第一个位置上,a
中该位置上的字符严格大于 b
中的对应字符,则认为字符串 a
字典序 大于 字符串 b
。
"abcd"
的字典序大于 "abcc"
,因为两个字符串出现不同的第一个位置对应第四个字符,而 d
大于 c
。示例 1:
输入:s = "100011001", k = 3 输出:"11001" 解释:示例中共有 7 个美丽子字符串: 1. 子字符串 "100011001" 。 2. 子字符串 "100011001" 。 3. 子字符串 "100011001" 。 4. 子字符串 "100011001" 。 5. 子字符串 "100011001" 。 6. 子字符串 "100011001" 。 7. 子字符串 "100011001" 。 最短美丽子字符串的长度是 5 。 长度为 5 且字典序最小的美丽子字符串是子字符串 "11001" 。
示例 2:
输入:s = "1011", k = 2 输出:"11" 解释:示例中共有 3 个美丽子字符串: 1. 子字符串 "1011" 。 2. 子字符串 "1011" 。 3. 子字符串 "1011" 。 最短美丽子字符串的长度是 2 。 长度为 2 且字典序最小的美丽子字符串是子字符串 "11" 。
示例 3:
输入:s = "000", k = 1 输出:"" 解释:示例中不存在美丽子字符串。
提示:
1 <= s.length <= 100
1 <= k <= s.length
- class Solution {
- static int S[];
- public int[] StringToInt(String s) {
- int ans[] = new int[s.length()];
- for (int i = 0; i < s.length(); i++) {
- if (s.charAt(i) == '0') {
- ans[i] = 0;
- } else {
- ans[i] = 1;
- }
- }
- return ans;
- }
- public String shortestBeautifulSubstring(String s, int k) {
- if(s.replace("0","").length()
- return "";
- String ans = "";
- S = StringToInt(s);
- int left = 0;
- int right = 0;
- int count = 0;
- for (right = 0; right < S.length; right++) { // Iterate based on the length of 's'
- count += S[right];
- while (count > k || S[left] == 0) {
- count -= S[left++];
- }
- if (count == k) {
- String t = s.substring(left, right + 1);
- if (ans.equals("") || t.length() < ans.length() || (t.length() == ans.length() && t.compareTo(ans) < 0)) {
- ans = t;
- }
- }
- }
- return ans;
- }
- }
这是一个左右滑动窗口的题目,因为是需要去寻找最短的满足和为k的字符串,所以说,只要是后面还有0就不是最短的,我们从left=0开始,让right向右遍历增加,如果此时的条件满足count==k,就说明此时找到了一个二进制和为k的字符串。我们得到此时的left和right范围的字符串,如果此时ans==0或者是t.length()