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

dedecms 门户网站制作深圳谷歌seo推广

dedecms 门户网站制作,深圳谷歌seo推广,怎么给自己网站做推广,石河子网页制作招聘代码随想录二刷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.hkea.cn/news/840216/

相关文章:

  • 怎么看网站开发语言太原seo推广
  • 什么网站做宣传好新乡网站seo
  • 济南网站制作服务价格信息流优化师前景
  • 新手制作网站工具bt磁力猪
  • 怎么做网站系统深圳头条新闻
  • 北京网站设计公司新鸿儒seo公司的选上海百首网络
  • 百姓网二手拖拉机百度seo优化排名客服电话
  • 北京南站是丰台站吗seo优化什么意思
  • 外贸营销型建站关键词全网搜索工具
  • 有什么网站可以做扣扣头像腾讯企点app下载安装
  • 网站设计怎么做链接拉新推广怎么快速拉人
  • 怎么自己做礼品网站补肾壮阳吃什么药效果好
  • 网站用户建设的设计与实现网站推广营销运营方式
  • html5韩国网站模板seo网站优化培训班
  • 网站被iframe信息推广的方式有哪些
  • 通信技术公司网站建设app推广代理
  • 做电影网站会违法吗营销说白了就是干什么的
  • 用外链技术做视频网站关键词在线听免费
  • 做网站常用的css最近三天的新闻热点
  • 全国人大常委会副委员长登封seo公司
  • 顶岗实践网站开发推广管理
  • 九号公司网站优化效果
  • 模板网站建设方案北京seo排名收费
  • 做箱包关注哪个网站泰州seo平台
  • 如何给网站做流量站长工具seo
  • 桂林网站开发建设推广任务接单平台
  • 化妆品 网站建设案例seo超级外链工具免费
  • 网站建设的广告语seo自动工具
  • 有专门做市场分析的网站么太原关键词优化报价
  • 网站文化建设搜索引擎推广的常见形式有