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

技术网站建设网站推广策划

技术网站建设,网站推广策划,PHP做的网站能容纳多少人,怎样建微信公众号代码随想录二刷Day9 今日任务 28.找出字符串中第一个匹配项的下标 459.重复的子字符串 字符串总结 双指针总结 语言:C KMP 链接:https://programmercarl.com/0459.重复的子字符串.html#kmp 用处:当出现字符串不匹配时,可以利…

代码随想录二刷Day9

今日任务

28.找出字符串中第一个匹配项的下标
459.重复的子字符串
字符串总结
双指针总结
语言:C++

KMP

链接:https://programmercarl.com/0459.重复的子字符串.html#kmp

  1. 用处:当出现字符串不匹配时,可以利用一部分之前已经匹配的内容,节省匹配时间,避免从头匹配
  2. 前缀表:用来回退的,即记录当模式串与主串不匹配时,模式串应该从哪个位置开始重新匹配;记录下标i之前(包括i)的字符串中,有多大长度的相同前缀后缀
  3. 最长相等前后缀:前缀指不包含最后一个字符的所有以第一个字符开头的连续子串;后缀指不包含第一个字符的所有以最后一个字符结尾的连续子串;前缀表要求的是相同前后缀的长度
  4. 前缀表为什么可以确定匹配失败后跳到哪里重新匹配?
    前缀表利用的是相同前后缀,所以如果在某个位置匹配失败后,可以根据前缀表找到失败位置后缀对应的前缀位置,直接跳到前缀相应位置重新匹配即可
  5. 前缀表和next数组之间的关系?
    next数组可以是前缀表,也可以是前缀表统一减1的结果,和KMP原理无关,主要是根据实现方便程度修改的
  6. 时间复杂度:O(m+n),模式串长度为m,文本串长度为n,建立模式串的时间复杂度为O(m),文本串匹配的时间复杂度为O(n)
  7. next数组构造过程:初始化,处理前后缀不同的情况,处理前后缀相同的情况,更新next数组
void getNext(int* next, string& s){int i = 0; //i表示最大前缀长度,初始化为0next[0] = i;for(int j = 1; j < s.length(); j++){ //j表示最大后缀长度,从1开始//处理前后缀不同的情况while(i > 0 && s[i] != s[j]){i = next[i - 1];}if(s[i] == s[j]){i++;}next[j] = i;}
}
}

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

链接:https://leetcode.cn/problems/find-the-index-of-the-first-occurrence-in-a-string/

class Solution {
public:void getNext(vector<int>& next, string& s){int i = 0;next[0] = i;for(int j = 1; j < s.length(); j++){while(i > 0 && s[i] != s[j]){i = next[i - 1];}if(s[i] == s[j]){i++;}next[j] = i;}}int strStr(string haystack, string needle) {int res = -1;vector<int> next(needle.length());getNext(next, needle);int j = 0; //needlefor(int i = 0; i < haystack.length(); i++){ //haystackwhile(j < next.size() && haystack[i] == needle[j]){i++;j++;}if(j > 0 && j < next.size() && haystack[i] != needle[j]){j = next[j - 1];i--; //这里要减1,否则会错位,比较推荐下面的写法}else if(j == next.size()){res = i - needle.length();break;}}//另一种写法/*for(int i = 0; i < haystack.length(); i++){ //haystackwhile(j > 0 && j < next.size() && haystack[i] != needle[j]){j = next[j - 1];}if(j < next.size() && haystack[i] == needle[j]){j++;}if(j == next.size()){res = i - needle.length() + 1;break;}}*/return res;}
};

459. 重复的子字符串

链接:https://leetcode.cn/problems/repeated-substring-pattern/
若一个字符串由重复子串构成,则最长相等前后缀不包含的子串就是最小重复子串,接下来可以根据长度关系简单判断字符串是否由重复子串构成

class Solution {
public:void getNext(vector<int>& next, string& s){int i = 0;next[0] = i;for(int j = 1; j < s.length(); j++){while(i > 0 && s[i] != s[j]){i = next[i - 1];}if(s[i] == s[j]){i++;}next[j] = i;}}bool repeatedSubstringPattern(string s) {vector<int> next(s.length());getNext(next, s);if(next[next.size() - 1] == 0) return false; //"abac"int len = s.length() - next[next.size() - 1];if(len != 0 && s.length() % len == 0) return true;return false;}
};
http://www.yidumall.com/news/73790.html

相关文章:

  • 汽车之家官方网站徐汇网站建设
  • 网站关键词收费今日全国最新疫情通报
  • 公司名称注册重名查询官网郑州网站优化推广
  • web技术有哪些seo这个行业怎么样
  • 网站开发百灵鸟收录优美图片崩了
  • 怎么做网站拍卖的那种北京关键词优化平台
  • 郑州做网站优化运营商快速建站工具
  • 关岭网站建设优化关键词排名软件
  • 网站备案幕布多少钱seo软件排行榜前十名
  • 基本的网站建设知识免费顶级域名申请网站
  • 潭州教育网站开发网络公司网络推广服务
  • 做一个网站指定页面的推广西地那非
  • 网站建设周记上海网站建设公司
  • 网站设计网站制作今日新闻网
  • 对网站政务建设的建议抖音关键词排名优化
  • 进口香烟网上商城西安百度网站快速优化
  • 公司网站制作定制专业seo关键词优化
  • 全景图网站怎么做全国十大教育机构
  • 老网站怎么做seo优化销售网站有哪些
  • 郑州网站建设三牛短视频营销推广策略
  • 找能做网站的抖音排名优化
  • 网站推广工作如何做线上线下推广方案
  • 元谋网站建设瑞昌网络推广
  • me域名网站seo优化总结
  • 政府网站必须做等保鞍山seo公司
  • 网页制作三剑客是什么意思东莞seo优化方案
  • 跨境收款网站内容如何优化
  • 二手书网站建设策划书螺蛳粉营销策划方案
  • 好的做网站的公司有哪些怎么弄自己的网站
  • 做当地门户网站多少钱优化 seo