⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 kmp.cpp

📁 kmp算法:查找一个字符串是不是另一个字符串的子串
💻 CPP
字号:
#include <vector>
#include <string>
using namespace std;
const vector<int> * kmp_next(string &m) // count the longest prefex string ; 
{ 
	static vector<int> next(m.size()); 
	next[0]=0; // the initialization of the next[0]; 

	int temp; // the key iterator...... 
	size_t nSz = next.size(), i;
	for(i = 1; i < nSz; i++) 	
	{ 
		temp=next[i-1]; 
		while(m[i] != m[temp] && temp>0) 
		{ 
			temp=next[temp-1]; 
		} 

		if(m[i] == m[temp]) 
			next[i] = temp + 1; 
		else next[i] = 0; 
	} 
	return &next; 
} 
bool kmp_search(string text,string m,int &pos) 
{ 
	const vector<int> * next = kmp_next(m); 

	int tp = 0; 
	int mp = 0; // text pointer and match string pointer; 
	int nSz = (int)text.size();
	for(tp = 0;tp < nSz; tp++) 
	{ 
		while(text[tp] != m[mp] && mp) 
			mp = (*next)[mp-1]; 

		if(text[tp] == m[mp]) 
			mp++; 

		if(mp == m.size()) 
		{ 
			pos = tp - mp + 1; 
			return true; 
		} 
	} 

	if(tp == text.size()) 
		return false; 
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -