字符串查找算法之暴力匹配算法实现JAVA

字符串查找暴力算法

文本串:ABADEFG 模式串: ADEF
(1)两个for循环实现

 public static int search(String pat, String txt){
	int M = pat.length;
	int N = txt.length;
	for(int i = 0; i <= N-M; i++){
		int j;
		for(j = 0; j < M; j++){
			if(txt.charAt(i+j) != pat.charAt(j)){
				break;
			}
			if(j == M) return i; //找到匹配
		}
	}
	return N;
}

(2)显示回退实现
相对(1)用两个for循环,我们进行一些改进,来对这两个for循环实现进行一些优化

public static int search(String pat, String txt){
	int M = pat.length;
	int N = txt.length;
	for(i = 0; j = 0; i < N && j < M; i++){
		if(txt.charAt(i) == pat.charAt(j)){
			//如果匹配,则将j++,本次循环结束,i++,继续下次循环,也就是对比新位置的两个字符
			j++;
		} else {
			/**
			如果不匹配了,就要回退,首先i回退到 i-j,比如首次回退,i-j=0,j=0,本次循环结束,i++得出下次循环 i=1,j=0,就算这样利用这种
			错位比较,有效避免的内部循环实现
			*/
			i -= j;
			j = 0;
		}
	}	
	if(j == M) return i - M; //找到匹配
	else return N; //未找到匹配
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值