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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用java编写输入两个字符串输出最大相同字符串相关的知识,希望对你有一定的参考价值。

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

这种东西一搜一大堆啊

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());

参考技术A 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);
参考技术B 不明白你的意思?

以上是关于用java编写输入两个字符串输出最大相同字符串的主要内容,如果未能解决你的问题,请参考以下文章

华为机试真题 Java 实现计算最大乘积

华为OD机试 - 计算最大乘积(Java) | 机试题+算法思路+考点+代码解析 2023

华为OD机试 - 计算最大乘积(Java) | 机试题+算法思路+考点+代码解析 2023

java实现输入输出编程

输入输出编程

用java编写一段程序,输入一段字符串,然后输出该字符串的倒序状态。