ZBLOG

现在有一个仅仅由小写字母组成的字符串 我需要截取一个子串 使得里面至少有 k 个相同的字母 子串的最小长度 golang 解决

要解决这个问题,我们可以使用滑动窗口的方法来找到满足条件的最小子串长度。具体步骤如下:

  1. 使用两个指针表示当前的窗口。
  2. 遍历字符串,扩展右指针以增加窗口大小。
  3. 使用一个字典(或者数组)来记录每个字符出现的次数。
  4. 当某个字符的出现次数达到 k 时,尝试缩小左指针,以获得更小的子串长度。

以下是用 Go 语言实现该思路的代码:

  1. package main
  2. import (
  3. "fmt"
  4. "math"
  5. )
  6. func minLengthSubstring(s string, k int) int {
  7. left, right := 0, 0
  8. count := make(map[rune]int)
  9. minLength := math.MaxInt32
  10. for right < len(s) {
  11. count[rune(s[right])]++
  12. // 检查当前窗口是否有至少一个字符出现了 k 次
  13. for char, freq := range count {
  14. if freq >= k {
  15. // 尝试收缩窗口
  16. for left <= right && count[rune(s[left])] > k-1 {
  17. count[rune(s[left])]--
  18. left++
  19. }
  20. // 更新最小长度
  21. minLength = min(minLength, right-left+1)
  22. }
  23. }
  24. right++
  25. }
  26. if minLength == math.MaxInt32 {
  27. return -1 // 表示没有找到符合条件的子串
  28. }
  29. return minLength
  30. }
  31. // Utility function to get minimum of two integers
  32. func min(a, b int) int {
  33. if a < b {
  34. return a
  35. }
  36. return b
  37. }
  38. func main() {
  39. s := "aaabbcc"
  40. k := 3
  41. result := minLengthSubstring(s, k)
  42. if result != -1 {
  43. fmt.Printf("The minimum length of the substring with at least %d identical letters is: %d\n", k, result)
  44. } else {
  45. fmt.Println("No valid substring found.")
  46. }
  47. }

示例:

如果输入字符串为 "aaabbcc"k = 3,则输出结果为 3,因为 "aaa" 是一个满足条件的子串。

注意事项:

  • 如果找不到任何满足条件的子串,将返回 -1
  • 可以根据需求调整测试案例以验证算法是否有效。如果还有其他问题,请告诉我!


    内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=19797

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?