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

}
相关推荐
java修仙传21 小时前
每日一题,力扣560. 和为 K 的子数组
算法·leetcode
ada7_21 小时前
LeetCode(python)——148.排序链表
python·算法·leetcode·链表
资深web全栈开发1 天前
LeetCode 3625. 统计梯形的数目 II
算法·leetcode·组合数学
橘颂TA1 天前
【剑斩OFFER】算法的暴力美学——外观数列
算法·leetcode·职场和发展·结构与算法
Pluchon1 天前
硅基计划4.0 算法 FloodFill算法
java·算法·leetcode·决策树·逻辑回归·深度优先·图搜索算法
Jac_kie_層樓1 天前
力扣hot100刷题记录(12.2)
算法·leetcode·职场和发展
foxsen_xia1 天前
Go安装、配置和vsCode配置Go
开发语言·vscode·golang
希望有朝一日能如愿以偿1 天前
力扣每日一题:统计梯形的数目
算法·leetcode·职场和发展
稚辉君.MCA_P8_Java1 天前
Gemini永久会员 go数组中最大异或值
数据结构·后端·算法·golang·哈希算法