LeetCode题解1297. 子串的最大出现次数

给你一个字符串 s ,请你返回满足以下条件且出现次数最大的 任意 子串的出现次数:

子串中不同字母的数目必须小于等于 maxLetters 。

子串的长度必须大于等于 minSize 且小于等于 maxSize 。

 

示例 1:

输入:s = "aababcaab", maxLetters = 2, minSize = 3, maxSize = 4

输出:2

解释:子串 "aab" 在原字符串中出现了 2 次。

它满足所有的要求:2 个不同的字母,长度为 3 (在 minSize 和 maxSize 范围内)。

示例 2:

输入:s = "aaaa", maxLetters = 1, minSize = 3, maxSize = 3

输出:2

解释:子串 "aaa" 在原字符串中出现了 2 次,且它们有重叠部分。

示例 3:

输入:s = "aabcabcab", maxLetters = 2, minSize = 2, maxSize = 3

输出:3

示例 4:

输入:s = "abcde", maxLetters = 2, minSize = 3, maxSize = 3

输出:0

 

提示:

1 <= s.length <= 10^5

1 <= maxLetters <= 26

1 <= minSize <= maxSize <= min(26, s.length)

s 只包含小写英文字母。

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/maximum-number-of-occurrences-of-a-substring

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

题解:Java题解 简单明了

注意题目细节中的maxSize范围,那么就可以发现暴力解法可以做。

其实可以用滑动窗口来做,窗口大小为minSize即可。理由大致如下:
- 一个大于minSize长度的字串若是满足条件,那么该字串其中必定有至少一个长度为minSize的字串满足条件。
- 因此一个大于minSize长度的字串出现了T次,那么该字串其中必定有一个长度为minSize的字串出现了T次。
``` java
public int maxFreq(String s, int maxLetters, int minSize, int maxSize) {

Map counter = new HashMap();
int res = 0;
for (int i = 0; i < s.length() - minSize + 1; i++) {

String substr = s.substring(i, i + minSize);
if (checkNum(substr, maxLetters)) {

int newVal = counter.getOrDefault(substr, 0) + 1;
counter.put(substr, newVal);
res = Math.max(res, newVal);
}
}

return res;
}

public boolean checkNum(String substr, int maxLetters) {

Set set = new HashSet();
for (int i = 0; i < substr.length(); i++)
set.add(substr.charAt(i));

return set.size() <= maxLetters;
}
```

Java中的“ <<”运算符 - java

最喜欢的语句来自Java的Character类:(1 << Character.PARAGRAPH_SEPARATOR)) >> type PARAGRAPH_SEPARATOR是字节,type是整数。这句话中的操作员,他们做什么?如何以及在哪里可以使用这些运算符?这是oracles java.lang.Character文档。该类中…

LeetCode题解计算机为什么是基于二进制的?

可以是三进制么?二进制有什么好处?题解:为什么叫电子计算机?算盘应该没有二进制

LeetCode题解深度优先遍历和回溯的关系?

深度优先遍历的范围更大还是回溯的范围更大?为什么?题解:我的理解是:dfs是回溯思想的一种体现- 回溯:是在整个搜索空间中搜索出可行解,在搜索过程中不断剪枝回退,这是回溯的思想,这个搜索空间并没有限制于特定的数据结构。- dfs:dfs是指特定的数据结构中如图,树(特殊的图)中搜索答案,范围限制在了特定的数据结构。个人拙见。

LeetCode题解盲人买袜子。

他们都各自买了两对黑袜和两对白袜,八对袜子的布质、大小完全相同,而每对袜子都有一张商标纸连着。两位盲人不小心将八对袜子混在一起。他们每人怎样才能取回黑袜和白袜各两对呢?题解:暴力破解, 把袜子都拆开 一人一只 哈哈

LeetCode题解10个小球,随机分到12个盒子里,求恰好10个盒子都为空的概率。

10个小球,随机分到12个盒子里,求恰好10个盒子都为空的概率。要求用程序模拟十万次,暴力求出该概率来自:字节跳动 算法工程师一面的第一题 (3月30日,60分钟,牛客网视频面)https://www.nowcoder.com/discuss/395924