当前位置: 首页 > wzjs >正文

小升初在线做试卷的网站济南网络seo公司

小升初在线做试卷的网站,济南网络seo公司,网站建设或网站优化排名,河南省建设人才教育信息网官网文章目录 习题28.找出字符串中第一个匹配项的下标1392.最长快乐前缀 本博客充分参考灵神和知乎的另一位博主 灵神KMP算法模版 知乎博主通俗易懂讲解 对于给定一个主串S和一个模式串P,如果让你求解出模式串P在主串S中匹配的情况下的所有的开始下标简单的做法又称为Brute-Force算…

文章目录

  • 习题
    • 28.找出字符串中第一个匹配项的下标
    • 1392.最长快乐前缀

本博客充分参考灵神和知乎的另一位博主

灵神KMP算法模版
知乎博主通俗易懂讲解

  • 对于给定一个主串S和一个模式串P,如果让你求解出模式串P在主串S中匹配的情况下的所有的开始下标
  • 简单的做法又称为Brute-Force算法,其实总的来说就是,外层循环遍历主串S,内存循环遍历模式串P,逐个匹配,当出现匹配不成功的情况,外层循环回到开始匹配位置+1,内层循环直接返回位置0,可想而知,这个算法的时间复杂度是o(n*m)
  • KMP算法的改进思路,就是比较的时候,肯定是一个个比较的,这个是不能改进的,主要是可以降低比较趟数
    • 外层循环主串S不会退,只回退模式串P,并且模式串P回退的时候充分利用真前缀和真后缀的最大匹配的长度!

话不多说,大家可以看上面知乎的讲解就可以啦!

KMP算法python 模版

模版解决的问题:在主串s中查找模式串p,返回所有成功匹配的位置

def kmp(s: str, p: str) -> List[int]:m = len(p)# next[i] 表示p[0] 到 p[i] 的真前缀和真后缀的最大匹配长度next = [0] * m# cnt 用于记录当前模式串p的真前缀和真后缀的最大匹配长度cnt = 0for i in range(1, m):b = p[i]while cnt and p[cnt] != b:cnt = pi[cnt - 1]if p[cnt] == b:cnt += 1next[i] = cnt# 记录答案pos = []# cnt 用于存储主串s和模式串p的匹配长度cnt = 0for i, b in enumerate(text):# 不相等就让模式串p回退while cnt and p[cnt] != b:cnt = next[cnt - 1]if p[cnt] == b:cnt += 1if cnt == len(p):pos.append(i - m + 1)# 注意这个cnt = next[cnt - 1]return pos

习题

28.找出字符串中第一个匹配项的下标

28.找出字符串中第一个匹配项的下标

在这里插入图片描述

  • 典型的KMP算法的模版题目
class Solution:def strStr(self, haystack: str, needle: str) -> int:# KMP算法m = len(needle)next = [0]*m cnt = 0# 预处理next数组for i in range(1,m):b = needle[i]while cnt and needle[cnt] != b :cnt = next[cnt-1]if needle[cnt] == b:cnt += 1next[i] = cnt # 开始匹配cnt = 0 for i,b in enumerate(haystack):while cnt and needle[cnt] != b:cnt = next[cnt-1]if needle[cnt] == b:cnt += 1if cnt == m:return i - m + 1return -1

1392.最长快乐前缀

1392.最长快乐前缀

在这里插入图片描述

  • 算法思路:直接使用KMP算法进行求解,最终的next[m-1]就是最大的长度
class Solution:def longestPrefix(self, s: str) -> str:# 这个就是knp算法的max(next)m = len(s)next = [0]*(m)cnt = 0 ans = 0for i in range(1,m):b = s[i]while cnt and s[cnt] != b:cnt = next[cnt-1]if s[cnt] == b:cnt += 1next[i] = cntreturn s[:next[m-1]] if next[m-1] > 0 else ""
http://www.dtcms.com/wzjs/273790.html

相关文章:

  • 宝鸡响应式网站开发站内seo优化
  • 做企业网站设计价格是多少网络宣传方式
  • 高端网站设计公司无忧seo
  • 昆明建设局官方网站百度优化插件
  • 做网站那个服务器好企业培训内容
  • 汕头seo网站管理公司网页制作模板
  • 免费网站报价单怎么做推广页面
  • 网站建设分几模块域名查询工具
  • 做网站要自己租服务器吗品牌策划方案模板
  • 成都网站建设推荐q479185700顶上网站设计模板
  • 做后期的网站有哪些网站建设小程序开发
  • 古城区建设局网站百度问问我要提问
  • 武汉网站建设平台自助建站申请
  • 常州低价网站建设公司百度百科推广费用
  • 白银区住房和城乡建设局网站绍兴seo排名公司
  • 哪些网站可以做免费推广百度网站推广怎么做
  • 邯郸做商城网站的公司湖北网络推广seo
  • 上海政府网站的建设的评价电脑培训班有哪些科目
  • 比较靠谱的软件下载网站惠州关键词排名优化
  • 广西建设网人员查询网宁波seo网络推广
  • 平面设计工作室网站郑州专业seo首选
  • 香港做一楼一凤的网站合法吗抖音seo是什么
  • rp网站做多大seo对各类网站的作用
  • wordpress用户修改头像seo站内优化公司
  • 北京网站建设工作室哪家好域名搜索引擎入口
  • 天水网站建设优化分析
  • 南通企业网站怎么建设生成关键词的软件
  • 美食网站建设方案软文文案范文
  • 帮人做网站要怎么赚钱吗安卓手机优化大师官方下载
  • 设计网站流程包括哪些百度极速版下载