string子串匹配(用string自带函数,不涉及char数组转换)

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;
}

 

posted @ 2021-06-18 18:46  输了怪队友  阅读(272)  评论(0编辑  收藏  举报