用java编写输入两个字符串输出最大相同字符串

用java编写输入两个字符串输出最大相同字符串... 用java编写输入两个字符串输出最大相同字符串 展开
 我来答
匿名用户
2015-07-14
展开全部

这种东西一搜一大堆啊

public class LCString3 {

public static void getLCString(char[] str1, char[] str2) {
int i, j;
int len1, len2;
len1 = str1.length;
len2 = str2.length;
int maxLen = len1 > len2 ? len1 : len2;
int[] max = new int[maxLen];
int[] maxIndex = new int[maxLen];
int[] c = new int[maxLen];

for (i = 0; i < len2; i++) {
for (j = len1 - 1; j >= 0; j--) {
if (str2[i] == str1[j]) {
if ((i == 0) || (j == 0))
c[j] = 1;
else
c[j] = c[j - 1] + 1;
} else {
c[j] = 0;
}

if (c[j] > max[0]) { // 如果是大于那暂时只有一个是最长的,而且要把后面的清0;
max[0] = c[j];
maxIndex[0] = j;

for (int k = 1; k < maxLen; k++) {
max[k] = 0;
maxIndex[k] = 0;
}
} else if (c[j] == max[0]) { // 有多个是相同长度的子串
for (int k = 1; k < maxLen; k++) {
if (max[k] == 0) {
max[k] = c[j];
maxIndex[k] = j;
break; // 在后面加一个就要退出循环了
}

}
}
}
}

for (j = 0; j < maxLen; j++) {
if (max[j] > 0) {
System.out.println("第" + (j + 1) + "个公共子串:");
for (i = maxIndex[j] - max[j] + 1; i <= maxIndex[j]; i++)
System.out.print(str1[i]);
System.out.println(" ");
}
}
}

public static void main(String[] args) {
String str1 = new String("helloworld");
String str2 = new String("hello,world");
getLCString(str1.toCharArray(), str2.toCharArray());
}
}
匿名用户
2015-07-14
展开全部
public static void main(String[] args) {
String str1="abcde";
String str2="abcdefg";
String result="";
for (int i = 0; i < str1.length(); i++) {
for(int j=0;j<str2.length();j++){
if(str1.charAt(i)==str2.charAt(j)){
result+=str1.charAt(i);
}
}
}
System.out.println(result);
}
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jsrdjz
2015-07-14 · TA获得超过156个赞
知道小有建树答主
回答量:473
采纳率:0%
帮助的人:91.1万
展开全部
不明白你的意思?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式