[wikioi]1204 寻找子串位置

1204 寻找子串位置

 时间限制: 1 s
 空间限制: 128000 KB
 题目等级 : 青铜 Bronze
题目描述 Description

给出字符串a和字符串b,保证b是a的一个子串,请你输出b在a中第一次出现的位置。

输入描述 Input Description

仅一行包含两个字符串a和b

输出描述 Output Description

仅一行一个整数

样例输入 Sample Input

abcd bc

样例输出 Sample Output

2

数据范围及提示 Data Size & Hint

字符串的长度均不超过100

Pascal用户请注意:两个字符串之间可能包含多个空格

本人菜鸟,如有说错的地方欢迎各位大牛指出。

关于字符串匹配算法是算法学习当中比较常见的了。

BF(Brute Force)算法是普通的模式匹配算法,BF算法的思想就是将目标串S的第一个字符与模式串T的第一个字符进行匹配,若相等,则继续比较S的第二个字符和 T的第二个字符;若不相等,则比较S的第二个字符和T的第一个字符,依次比较下去,直到得出最后的匹配结果。BF算法是一种蛮力算法。

BF暴力

#include<cstdio>
#include<cstring>
#include<string>
#include<iostream>
using namespace std;
int BFMatch(char *s,char *p)
{
	int i,j;
	i=0;
	while(i<strlen(s))
	{
		j=0;
		while(s[i]==p[j]&&j<strlen(p))
		{
			i++;
			j++;
		}
		if(j==strlen(p))
			return i-strlen(p);
		i=i-j+1;                //指针i回溯
	}
	return -1;
}
int main()
{
    char a[1000],b[1000];
    cin>>a>>b;
    int s=BFMatch(a,b);
    cout<<s+1<<endl;
}


kmp算法是一种改进的字符串匹配算法,由D.E.Knuth与V.R.Pratt和J.H.Morris同时发现,因此人们称它为克努特——莫里斯——普拉特操作(简称KMP算法)。KMP算法的关键是根据给定的模式串W1,m,定义一个next函数。next函数包含了模式串本身局部匹配的信息。

KMP

#include<cstdio>
#include<string>
#include<iostream>
using namespace std;
int p[101];
int main()
{
    string a,b;
    cin>>a>>b;
    int n=a.length(),m=b.length();
    a=" "+a;b=" "+b;
    int j=0;
    for(int i=2;i<=m;i++)
    {
        while(j>0&&b[j+1]!=b[i])
        j=p[j];
        if(b[j+1]==b[i])
        j++;
        p[i]=j;
    }
    j=0;
    for(int i=1;i<=n;i++)
    {
        while(j>0&&b[j+1]!=a[i])
        j=p[j];
        if(b[j+1]==a[i])
        j++;
        if(j==m)
        {
            printf("%d",i-m+1);
            break;
        }
    }
    return 0;
}









你可能感兴趣的:([wikioi]1204 寻找子串位置)