首页
题库
面试
求职
学习
竞赛
More+
所有博客
搜索面经/职位/试题/公司
搜索
我要招人
去企业版
登录 / 注册
首页
>
试题广场
>
kmp算法
[编程题]kmp算法
热度指数:35654
时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 256M,其他语言512M
算法知识视频讲解
给你一个
文本串
T ,一个
非空模板串
S ,问 S 在 T 中出现了多少次
数据范围:
要求:空间复杂度
,时间复杂度
示例1
输入
"ababab","abababab"
输出
2
示例2
输入
"abab","abacabab"
输出
1
马上挑战
算法知识视频讲解
提交运行
算法知识视频讲解
添加笔记
求解答(0)
邀请回答
收藏(599)
分享
提交结果有问题?
2个回答
78篇题解
添加回答
1
Python3
游客留步牛
class
Solution
:
def
kmp
(
self
,
S
:
str
,
T
:
str
) ->
int
:
# write code here
def
pre_process
(
S
):
'''
输出前缀表
'''
next_string = [
0
]*
len
(S)
j =
0
for
i
in
range
(
1
,
len
(S)):
while
j >
0
and
S[j] != S[i]:
j = next_string[j-
1
]
if
S[i] == S[j]:
j+=
1
next_string[i] = j
return
next_string
next_string = pre_process(S)
j =
0
#指向S的当前字符
count =
0
#记录S在T中出现的次数
for
i
in
range
(
len
(T)):
while
j >
0
and
T[i] !=S[j]:
j = next_string[j-
1
]
if
T[i] == S[j]:
j+=
1
if
j ==
len
(S):
#如果把S遍历完全,则视为出现一次
count +=
1
j = next_string[j-
1
]
return
count
编辑于 2023-12-21 00:21:56
回复(0)
0
Python3
牛客832605738号
#超长字符串超时
class
Solution
:
def
kmp
(
self
,
S
:
str
,
T
:
str
) ->
int
:
# write code here
while
True
:
try
:
m=
len
(S)
a=
0
for
i
in
range
(
len
(S)+
1
):
if
T[i:i+m]==S:
a+=
1
return
a
except
:
break
发表于 2022-10-20 15:32:00
回复(0)
这道题你会答吗?花几分钟告诉大家答案吧!
提交观点
问题信息
字符串
难度:
2条回答
599收藏
11408浏览
热门推荐
通过挑战的用户
查看代码
skylark...
2023-02-04 20:01:37
牛客27327...
2022-10-04 13:06:13
牛客76427...
2022-09-20 21:53:21
牛客72914...
2022-09-17 07:46:02
NewArhan
2022-09-16 15:09:07
相关试题
下面伪代码程序: C...
Java工程师
C++工程师
安卓工程师
运维工程师
算法工程师
商汤科技
2018
嵌入式工程师
评论
(1)
来自
嵌入式工程师能力评估
在Java语言中,关于集合框架类的...
Java
评论
(1)
大模型的“集成学习”主要是指什么?
大模型概念
评论
(1)
评估大型语言模型生成文本质量时,R...
大模型概念
评论
(1)
关于大模型推理优化的技术方向,最符...
大模型概念
评论
(1)
kmp算法
扫描二维码,关注牛客网
意见反馈
下载牛客APP,随时随地刷题
import java.util.*; public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 计算模板串S在文本串T中出现了多少次 * @param S string字符串 模板串 * @param T string字符串 文本串 * @return int整型 */ public int kmp (String S, String T) { // write code here } }
class Solution { public: /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 计算模板串S在文本串T中出现了多少次 * @param S string字符串 模板串 * @param T string字符串 文本串 * @return int整型 */ int kmp(string S, string T) { // write code here } };
#coding:utf-8 # # 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 # # 计算模板串S在文本串T中出现了多少次 # @param S string字符串 模板串 # @param T string字符串 文本串 # @return int整型 # class Solution: def kmp(self , S , T ): # write code here
using System; using System.Collections.Generic; class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 计算模板串S在文本串T中出现了多少次 * @param S string字符串 模板串 * @param T string字符串 文本串 * @return int整型 */ public int kmp (string S, string T) { // write code here } }
/** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 计算模板串S在文本串T中出现了多少次 * @param S string字符串 模板串 * @param T string字符串 文本串 * @return int整型 */ function kmp( S , T ) { // write code here } module.exports = { kmp : kmp };
# # 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 # # 计算模板串S在文本串T中出现了多少次 # @param S string字符串 模板串 # @param T string字符串 文本串 # @return int整型 # class Solution: def kmp(self , S: str, T: str) -> int: # write code here
package main import "fmt" /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 计算模板串S在文本串T中出现了多少次 * @param S string字符串 模板串 * @param T string字符串 文本串 * @return int整型 */ func kmp( S string , T string ) int { // write code here }
/** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 计算模板串S在文本串T中出现了多少次 * @param S string字符串 模板串 * @param T string字符串 文本串 * @return int整型 */ int kmp(char* S, char* T ) { // write code here }
# # 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 # # 计算模板串S在文本串T中出现了多少次 # @param S string字符串 模板串 # @param T string字符串 文本串 # @return int整型 # class Solution def kmp(S, T) # write code here end end
object Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 计算模板串S在文本串T中出现了多少次 * @param S string字符串 模板串 * @param T string字符串 文本串 * @return int整型 */ def kmp(S: String,T: String): Int = { // write code here } }
object Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 计算模板串S在文本串T中出现了多少次 * @param S string字符串 模板串 * @param T string字符串 文本串 * @return int整型 */ fun kmp(S: String,T: String): Int { // write code here } }
import java.util.*; public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 计算模板串S在文本串T中出现了多少次 * @param S string字符串 模板串 * @param T string字符串 文本串 * @return int整型 */ public int kmp (String S, String T) { // write code here } }
/** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 计算模板串S在文本串T中出现了多少次 * @param S string字符串 模板串 * @param T string字符串 文本串 * @return int整型 */ export function kmp(S: string, T: string): number { // write code here }
public class Solution { /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 计算模板串S在文本串T中出现了多少次 * @param S string字符串 模板串 * @param T string字符串 文本串 * @return int整型 */ func kmp ( _ S: String, _ T: String) -> Int { // write code here } }
struct Solution{ } impl Solution { fn new() -> Self { Solution{} } /** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * * 计算模板串S在文本串T中出现了多少次 * @param S string字符串 模板串 * @param T string字符串 文本串 * @return int整型 */ pub fn kmp(&self, S: String, T: String) -> i32 { // write code here } }
"ababab","abababab"
2
"abab","abacabab"
1