java中比较两个字符串,并输出最大相似长度

 我来答
追梦_Java
2011-06-09
知道答主
回答量:15
采纳率:0%
帮助的人:0
展开全部
public class Test{
public static void main(String[] args){
subStr("abcdefghijklmn", "abcefgilk"); //把这两个参数改成你要比较的就可以了
}
public static void subStr(String s1, String s2){
String[] str = new String[20]; \\这个地方的大小根据需要改动
int n = 0;
for(int i = 0; i < s2.length(); i++){
for(int j = i + 1; j <= s2.length(); j++){
if(s1.indexOf(s2.substring(i, j)) != -1){
str[n] = s2.substring(i,j);
n++;
}
}
}
int maxLen = str[0].length();
for(int i = 1; i < n; i++){
if(str[i].length() >= maxLen)
maxLen = str[i].length();
}
for(int i = 0; i < n; i++){
if(str[i].length() == maxLen)
System.out.println(str[i]);
}

}
}
shitou51920
2011-06-17 · TA获得超过140个赞
知道答主
回答量:31
采纳率:0%
帮助的人:43.8万
展开全部
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class Test5 {
public static void main(String[] args) {
String str1 = "abc";
String str2 = "abcdefgh";
if(str1.length() > str2.length())
{
compare(str2,str1);
}else
{
compare(str1,str2);
}
}

private static void compare(String smallStr, String bigStr) {
String str = "";
Pattern p = null;
Matcher m = null;
for(int i=0 ; i<smallStr.length() ; i++)
{
//Advanced_bravely
str = str + smallStr.charAt(i);
p = Pattern.compile("^" + str + smallStr.substring(i+1));
m = p.matcher(bigStr);
if(m.find())
{
continue;
}else
{
str = str.substring(0,i);
break;
}
}
System.out.println("最大相似字符串为" + str);
System.out.println("最大相似长度为:" + str.length());
}
}
//自己测了下,可以用
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
迎风望月chen
2011-06-03 · 超过10用户采纳过TA的回答
知道答主
回答量:21
采纳率:0%
帮助的人:0
展开全部
给你一个思路:
首先从两个字符串当中,找到比较短的那个字符串x
然后从x的最左侧开始,
先找第一位去长的字符串当中比对,用contain或者indexof
如果存在,则把第一,第二位再次去比较
一次类推,到不存在为止。记录下该字符串
再从第二位开始
以此执行上面的步骤,得到字符串,和之前得出的字符串比较长度
记录下比较长的那个字符串。
经过迭代之后,如果记录下的字符串长度已经大于剩下的x的长度,就不需要再迭代了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
ymiqplgao
2011-06-02 · TA获得超过646个赞
知道小有建树答主
回答量:512
采纳率:0%
帮助的人:394万
展开全部
什么叫最大相似长度,没理解,额
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式