一、问题描述
给定主串S,判断模式串F是否是S的子串,如果是则返回T在S中出现的第一个位置,否则返回0。
二、算法思想
使用暴力算法解题,从主串S的第一个字符开始和模式串T的第一个字符进行比较,若相等则比较二者后续字符,否则,主串回溯到第二个字符,模式串回溯到第一个字符;继续比较,不匹配,主串回溯到第三个字符,模式串回溯到第一个字符。重新上述过程,直到模式串T中的字符全部比较完毕,说明匹配成功;否则匹配失败。
暴力算法将每一种情况都列举了出来,时间复杂度很高
三、代码实现
#include <iostream>
using namespace std;
int BF(char *S,char *T){
int i=0,j=0;
while(S[i]!='\0'&&T[j]){
if(S[i]==T[j]){
i++;
j++;
}else{
i=i-j+1;//主串回溯到上次回溯位置的下一个位置
j=0;//模式串回溯到第一个位置
}
}
if(T[j]=='\0')
return i-j+1; //返回T在S中第一次出现的位置
else return 0;
}
int main(){
char S[50]={'a','b','a','c','b','a','b','c'};
char T[50]={'b','a','b','c'};
cout<<BF(S,T)<<"\n";
return 0;
}