求两个字符串的最长的连续公共子串(按位异或法)

今天做最大的连续公共子串问题想到的

举个例子:子串是acbac,母串是acaccbabb

主要的思想是按位异或,连续的0就是连续的公共子串,记录最长出现的0:

以此类推,每次异或记录如果是0长度就加一并且记录最大长度,不是0就将长度清零。大概思想就是这样

代码如下

public class Main {
	public static void main(String[] args) {
		//子串
		String query = "acbac";
		//母串
		String text = "acaccbabb";
		//母串数组
		char t[] = new char[2*query.length() + text.length() - 2];
		for(int i = query.length() - 1, j = 0; j < text.length(); j++, i++) {
			t[i] = text.toCharArray()[j];
		}
		//子串数组
		char q[] = query.toCharArray();
		//异或结果数组
		int temp = 0;
		int max = 0;
		//按位异或
		for(int i = 0; i < t.length - query.length() + 1; i++) {
			int length = 0;
			for(int j = 0, k = i; j < query.length(); j++, k++) {
				temp = q[j] ^ t[k];
				if(temp == 0) {
					length ++;//长度加一
					if(length > max)//记录最大长度
						max = length;
				} else {
					length = 0;//清零
				}
			}
		}
		System.out.println(max);
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值