求最大公共子串和长度

求最大公共子串和长度问题就是:
求两个串的所有子串中能够匹配上的最长字串和最大长度是多少。
比如:s1="abcdkkk" 和 s2="baabcdadabc",
可以找到的最长的公共子串是"abcd",最大公共子串长度为4。
输入:

sdgadsgsh
oljdgadsgop

输出:

6
dgadsg

输入:

ssdf
jytyjj

输出:

0
null

解析:可以用矩阵法进行求解,用s1字符串的每一个字符串和s2中的所有字符进行比较,先定义一个二维数组a[s1长度+1][s2长度+1],a[i][j]代表的是s1中的一个字符和s2中每一个字符比较的状态,二维数组中一开始默认位置都为0,如果s1和s2对应的位置字符不同,则让a[i][j]为0。如果在对应字符相同的情况下,则看一下对应位置之前的位置即a[i-1][j-1]是不是为0,如果为0则说明则构不成连续子串,否则可以构成连续子串,让a[i][j] = a[i-1][j-1]+1。

代码如下:

public class 最大公共子串
{
	private static String cnt = "";    //最大字串起始为空串
	
	public static int Max(String s1,String s2)
	{
		int max = 0;
		char[] c1 = s1.toCharArray();      //将s1转换为字符数组
		char[] c2 = s2.toCharArray();      //将s2转换为字符数组
		int[][] a = new int[c1.length+1][c2.length+1];//s1中每一个字符都和s2中所有的字符比较
		for(int i=1,x=a.length;i<x;++i)  //a[i][j]代表s1中一个字符和s2中某一个字符的对应位置情况
		{
			for(int j=1,y=a[i].length;j<y;++j)   //
			{
				if(c1[i-1]==c2[j-1])//如果这两个字符相同,该位置+1之前应加上前一个位置的状态
				{
					a[i][j] = a[i-1][j-1]+1;    
				}
				if(a[i][j]>max)   //更新最大值
				{
					max = a[i][j];                 //例如:s1="kkabcdk"  最后一个位置是6
//					System.out.println(i+" "+j);  //i起始值是从1开始的,i代表s1中最大长度字串最后一个字符是第几个
					cnt = s1.substring(i-max,i);
				}
			}
		}
		return max;
	}
	
	public static void main(String[] args)
	{
		Scanner in = new Scanner(System.in);
		String s1 = in.next();
		String s2 = in.next();
		System.out.println(Max(s1,s2));   //最大字串的长度
		if(cnt==null||cnt=="")
		{
			System.out.println("null");    //没有匹配到
		}
		else
		{
			System.out.println(cnt);          //最大字串
		}
	}
}

运行结果:

输入:

sdgadsgsh
oljdgadsgop

输出:

6
dgadsg

输入:

ssdf
jytyjj

输出:

0
null

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值