字符串匹配算法KMP算法

字符串匹配算法

方法1 是使用暴力方法

方法2 是使用KMP算法


import java.util.Scanner;

/** 
* @author xiaohao 	
* @date 创建时间:Jul 29, 2017 4:05:17 PM 
* @version 1.0   
*/
public class SubstringSearch {

	public static void main(String[] args) {
		// TODO Auto-generated method stub

		Scanner in = new Scanner(System.in);
		while(in.hasNext()){
			String text=in.nextLine();
			String pattern=in.nextLine();			
			System.out.println(KMP(text,pattern));
			}
	}
	/*
	 * 暴力方法,时间复杂度 n*m
	 */
	public static boolean hasSubstring(String text,String pattern){
		char pShortString[]=pattern.toCharArray();
		char pLongString[]=text.toCharArray();
		int n=pLongString.length;
		int m=pShortString.length;
		for(int i=0;i<=n-m;i++)
		{
			int j=0;//每次循环都从模式串pattern的0位置开始比较
			while(j<m && pShortString[j]==pLongString[i+j]){
				j++;
			}
			if(j==m)
				return true;
		}		
		return false;
	}

	/*
	 * KMP算法,时间复杂度n+m
	 * 空间复杂度m
	 */
	public static boolean KMP(String text,String pattern){
		char pShortString[]=pattern.toCharArray();
		char pLongString[]=text.toCharArray();
		int n=pLongString.length;
		int m=pShortString.length;
		int lps[]= computeTemporaryArray(pattern);
		int i=0;
		int j=0;
		while(i<n&&j<m){
			if(pLongString[i]==pShortString[j])
			{
				i++;
				j++;
			}
			else{
				if(j!=0){//关键步,利用前缀表达式计算下一步开始比较的pattern串的位置,而不是从头开始
					j=lps[j-1];
				}
				else{
					i++;
				}
			}			
		}
		if(j==m)
			return true;
		return false;
		
	}
	/*
	 * 计算前缀表达式数组
	 */
	public static int[] computeTemporaryArray(String pattern) {
		// TODO Auto-generated method stub
		char[] str=pattern.toCharArray();
		int[] lps=new int[str.length];
		int left=0;
		int right=1;
		while(right<str.length){
			if(str[left]==str[right]){
				lps[right]=left+1;
				left++;
				right++;
			}
			else{
				if(left!=0){
					left=lps[left-1];
				}else{
					lps[right]=0;
					right++;
				}
			}
		}
		return lps;
	}
}

参考

https://www.bilibili.com/video/av3246487/?from=search&seid=5075218438614903583

https://www.bilibili.com/video/av11866460/?from=search&seid=5075218438614903583

https://github.com/mission-peace/interview/blob/master/src/com/interview/string/SubstringSearch.java

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值