2024-12-14:K 周期字符串需要的最少操作次数。用go语言,给定一个长度为n的字符串 word 和一个整数k,k是n的因数。每次操作可以选择两个下标i和j,使得i和j都可以被k整除,然后用从j
2024-12-14:K 周期字符串需要的最少操作次数。用go语言,给定一个长度为n的字符串 word 和一个整数k,k是n的因数。每次操作可以选择两个下标i和j,使得i和j都可以被k整除,然后用从j开始的长度为k的子串替换从i开始的长度为k的子串。要使得word成为一个K周期字符串,需要进行最少的操作次数。
一个K周期字符串是指存在一个长度为k的字符串s,通过多次连接s可以得到word。比如,如果word == "ababab",那么当s = "ab"时,word是一个2周期字符串。
现在,请计算使word成为K周期字符串所需的最少操作次数。
1 <= n == word.length <= 100000。
1 <= k <= word.length。
k 能整除 word.length 。
word 仅由小写英文字母组成。
输入:word = "leetcodeleet", k = 4。
输出:1。
解释:可以选择 i = 4 和 j = 0 获得一个 4 周期字符串。这次操作后,word 变为 "leetleetleet"。
答案2024-12-14:
题目来自leetcode3137。
大体步骤如下:
1.初始化变量 n 为字符串 word 的长度,并设定变量 res 初始值为最大整数。
2.创建一个空的计数映射 count,用于存储不同子串的出现次数。
3.遍历字符串 word 中长度为 k 的子串,依次检查每个子串。
4.在循环中,统计每个长度为 k 的子串出现的次数,更新 res 为使得 word 成为 K 周期字符串所需的最少操作次数。
5.返回最少操作次数 res。
总体时间复杂度:
-
遍历整个字符串 word 需要 O(n/k) 的时间。
-
在每一步中,计算和更新 res 的时间复杂度为 O(1)。
-
因此,总体时间复杂度为 O(n/k)。
总体额外空间复杂度:
-
需要额外的空间来存储计数映射 count,其大小取决于字符串中包含 unique 子串的数量,最坏情况下可达到 O(n/k)。
-
因此,总体额外空间复杂度为 O(n/k)。
Go完整代码如下:
package main
import (
"fmt"
"math"
)
func minimumOperationsToMakeKPeriodic(word string, k int) int {
n, res := len(word), math.MaxInt
count := map[string]int{}
for i := 0; i < n; i += k {
count[word[i:i+k]]++
res = min(res, n/k-count[word[i:i+k]])
}
return res
}
func main() {
word := "leetcodeleet"
k := 4
fmt.Println(minimumOperationsToMakeKPeriodic(word, k))
}
Rust完整代码如下:
use std::collections::HashMap;
fn min_operations_to_make_k_periodic(word: &str, k: usize) -> i32 {
let n = word.len();
let mut res = i32::MAX;
let mut count: HashMap<&str, i32> = HashMap::new();
for i in (0..n).step_by(k) {
let sub_str = &word[i..i+k];
*count.entry(sub_str).or_insert(0) += 1;
res = res.min((n / k) as i32 - *count.get(&sub_str).unwrap_or(&0));
}
res
}
fn main() {
let word = "leetcodeleet";
let k = 4;
println!("{}", min_operations_to_make_k_periodic(word, k));
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· Manus的开源复刻OpenManus初探
· 写一个简单的SQL生成工具
2023-12-14 文心一言 VS 讯飞星火 VS chatgpt (156)-- 算法导论12.3 3题
2022-12-14 2022-12-14:给定一个正数n, 表示从0位置到n-1位置每个位置放着1件衣服 从0位置到n-1位置不仅有衣服,每个位置还摆着1个机器人 给定两个长度为n的数组,powers和rates pow
2022-12-14 pg数据库的备份和恢复以及sql脚本错误的解决方法
2022-12-14 pg序列的增删改查
2022-12-14 pgadmin数据输出不存在了?
2021-12-14 2021-12-14:根据身高重建队列。 假设有打乱顺序的一群人站成一个队列,数组 people 表示队列中一些人的属性(不一定按顺序)。每个 people[i] = [hi, ki] 表示第 i 个
2020-12-14 2020-12-14:mysql中,可重复读是怎么实现的?