using namespace std; #include <iostream> #include<string> //第1种,用string自带的s.subdtr()截取任意子串,再用s.compare()确定是否与待求子串相等,时间复杂度O(len1*len2) int index1(string s,string t) { int i = 1; int len1 = s.length(); //主串长度 int len2 = t.length(); //子串长度 string sub; //用来放每次找到的临时子串 while (i <= len1 - len2 + 1) { //最大位置,再往后就凑不齐子串长度了 sub=s.substr(i, len2); //找从i开始长度一样的子串 if (sub.compare(t) == 0) {//比较是否一样 cout << "index1找到子串为:" << s.substr(i, t.length()) << endl; return i; //一样则找到了,不再循环 } else i++; //不一样则继续往后找 } //while结束 找到头了证明没有 return 0; } //第2种,用i和j同步遍历主串和子串,一旦有不一样的字符,重头来过,i起始位置往后移一位,j还原,时间复杂度O(len1*len2) int index2(string s, string t) { int i = 0, j = 0; //初始下标为0 while (i < s.length() && j < t.length()) { //循环条件当然是分别不超过长度 if (s[i] == t[j]) { //如果字符相同,则同步往后一个继续比对 i++; j++; } else { //如果不同,不用往后比对了,开始i往后一位重新比对 i = i - j + 1; //i退回到这次比对开始的位置i-j,然后往后一位 j = 0; //j退回到0 } } //while结束,要么i找完了,要么j找完了 if (j >= t.length()) { //要么j找完i没找完,要么i和j都找完了 cout <<"index2找到子串为:" << s.substr(i - j, t.length()) << endl; return i - t.length(); //这次比对开始的位置i-j或写i-t.length() } else //要么i找完但是j没找完 return 0; } void main() { string sf = "ababcabcacbab"; string sz = "abcac"; cout <<"index1 i下标:"<< index1(sf, sz) << endl; cout << "index2 i下标:" << index2(sf, sz) << endl; }
string子串匹配(用string自带函数,不涉及char数组转换)
原文:https://www.cnblogs.com/lucio1128/p/14900882.html