ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

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

2021-06-18 19:04:01  阅读:131  来源: 互联网

标签:子串 string int len1 char len2 length


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,int,len1,char,len2,length
来源: https://www.cnblogs.com/lucio1128/p/14900882.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有