Golang | Leetcode Golang题解之第466题统计重复个数

题目:

题解:

Go 复制代码
func getMaxRepetitions(s1 string, n1 int, s2 string, n2 int) int {
	n := len(s2)
	cnt := make([]int, n)
	for i := 0; i < n; i++ {
        // 如果重新给一个s1 并且s2是从第i位开始匹配 那么s2可以走多少位(走完了就从头开始走
		p1, p2 := 0, i
		for p1 < len(s1) {
			if s1[p1] == s2[p2 % n] {
				p2++
			}
            p1++
		}
        // 统计如果是从s2的第i位开始走 给一个新的s1 s2能走多少位
		cnt[i] = p2 - i
	}
	index := 0
    // 直接模拟不断给s1 然后看s2能新走多少位
	for i := 0; i <n1; i++ {
		index += cnt[index % n]
	}
	return index / n / n2

}
相关推荐
程序猿小白日记28 分钟前
走向智能化:从编程语言看人工智能的未来
leetcode
喵了几个咪3 小时前
Golang微服务框架kratos实现Socket.IO服务
开发语言·微服务·golang
天选之女wow3 小时前
【Hard——Day8】65.有效数字、68.文本左右对齐、76.最小覆盖子串
linux·运维·redis·算法·leetcode
2501_941800884 小时前
5G技术引领下的智能制造革命:如何推动工业4.0发展
leetcode
小白程序员成长日记4 小时前
2025.11.21 力扣每日一题
算法·leetcode·职场和发展
海奥华26 小时前
分库分表技术详解:从入门到实践
数据库·后端·mysql·golang
sin_hielo6 小时前
leetcode 1930
算法·leetcode
努力学算法的蒟蒻8 小时前
day17(11.18)——leetcode面试经典150
算法·leetcode·面试
不爱编程爱睡觉8 小时前
代码随想录算法训练营第二十八天 | 动态规划算法基础、 LeetCode509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
算法·leetcode·动态规划·代码随想录
yagamiraito_15 小时前
757. 设置交集大小至少为2 (leetcode每日一题)
算法·leetcode·go