使用kotlin解决这个题目:395. 至少有 K 个重复字符的最长子串 中等 819 相关企业 给你一个字符串 s 和一个整数 k ,请你找出 s 中的最长子串, 要求该子串中的每一字符出现次数都不少于 k 。返回这一子串的长度。 示例 1: 输入:s = "aaabb", k = 3 输出:3 解释:最长子串为 "aaa" ,其中 'a' 重复了 3 次。 示例 2: 输入:s = "ababbc", k = 2 输出:5 解释:最长子串为 "ababb" ,其中 'a' 重复了 2 次, 'b' 重复了 3 次。
时间: 2024-02-02 11:04:50 浏览: 26
可以使用分治算法来解决这个问题。首先统计字符串中每个字符出现的次数,然后遍历字符串,找到第一个出现次数小于 k 的字符,将其作为分割点,将字符串分成左右两部分。递归处理左右两部分,返回两部分中的最大值即可。
Kotlin 代码如下:
```kotlin
fun longestSubstring(s: String, k: Int): Int {
val n = s.length
if (n < k) return 0
val count = IntArray(26)
for (c in s) {
count[c - 'a']++
}
var split = 0
while (split < n && count[s[split] - 'a'] >= k) {
split++
}
if (split == n) return n
val left = longestSubstring(s.substring(0, split), k)
while (split < n && count[s[split] - 'a'] < k) {
split++
}
val right = longestSubstring(s.substring(split), k)
return maxOf(left, right)
}
```
这个算法的时间复杂度为 O(n log n),其中 n 是字符串的长度。
相关问题
使用kotlin完成这个题目:459. 重复的子字符串 给定一个非空的字符串 s ,检查是否可以通过由它的一个子串重复多次构成。
这道题可以使用字符串匹配的方法来解决。
具体来说,我们可以将原始字符串 s 拼接自身,然后去掉开头和结尾两个字符,这样得到的字符串一定包含原始字符串 s。
接下来,我们可以使用 KMP 算法或者 Z 算法来求出该字符串的前缀函数或者 Z 函数,然后判断原始字符串 s 的长度是否等于这个函数的最后一个值,如果是,说明原始字符串 s 可以由一个子串重复多次构成。
具体实现可以参考以下代码:
```kotlin
fun repeatedSubstringPattern(s: String): Boolean {
val n = s.length
val str = s + s
val pi = IntArray(n * 2)
var j = 0
for (i in 1 until n * 2) {
while (j > 0 && str[i] != str[j]) {
j = pi[j - 1]
}
if (str[i] == str[j]) {
j++
}
pi[i] = j
}
return pi[n * 2 - 1] != 0 && n % (n - pi[n * 2 - 1]) == 0
}
```
其中,`pi` 数组表示字符串 `str` 的前缀函数,`j` 表示匹配的长度,初始值为 `0`。
在循环中,我们不断地向右移动指针 `i`,并且不断地将 `j` 更新为 `pi[j-1]`,直到 `str[i]` 和 `str[j]` 相等,或者 `j` 为 `0`。如果 `str[i]` 和 `str[j]` 相等,我们就将 `j` 增加 1,并且将 `pi[i]` 赋值为 `j`。
最后,我们判断 `pi[n*2-1]` 是否为 0,并且判断 `n` 是否能被 `n-pi[n*2-1]` 整除。如果是,说明原始字符串 s 可以由一个子串重复多次构成,返回 true,否则返回 false。
希望能对你有所帮助!
使用kotlin完成这个题目:1156. 单字符重复子串的最大长度 如果字符串中的所有字符都相同,那么这个字符串是单字符重复的字符串。 给你一个字符串 text,你只能交换其中两个字符一次或者什么都不做,然后得到一些单字符重复的子串。返回其中最长的子串的长度。 示例 1: 输入:text = "ababa" 输出:3
好的,以下是使用 Kotlin 实现的代码:
```kotlin
fun maxRepOpt1(text: String): Int {
val n = text.length
val count = IntArray(26)
for (c in text) {
count[c - 'a']++
}
var maxLen = 1
for (i in 0 until n) {
var j = i + 1
while (j < n && text[j] == text[i]) {
j++
}
val len = j - i
if (len > maxLen) {
maxLen = len
}
if (len == count[text[i] - 'a']) {
continue
}
if (j < n && text[j] == text[i]) {
var k = j + 1
while (k < n && text[k] == text[i]) {
k++
}
if (k - i == count[text[i] - 'a']) {
maxLen = maxOf(maxLen, k - i)
}
} else {
if (len == count[text[i] - 'a'] - 1) {
maxLen = maxOf(maxLen, len + 1)
}
}
}
return maxLen
}
```
主要思路是遍历每个字符,记录下每个字符出现的次数,然后根据条件判断是否进行交换字符,从而得到最长的单字符重复子串的长度。具体实现细节可以看代码中的注释。