滑动窗口,双指针从最短的字符串截取子串,和长字符串做匹配。 从最长的短子串开始匹配。 定义头指针start, 尾指针end, 遍历所有子串
import java.util.Scanner;
import java.util.Arrays;
// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
// 注意 hasNext 和 hasNextLine 的区别
while (in.hasNextLine()) { // 注意 while 处理多个 case
String a = in.nextLine();
String b = in.nextLine();
System.out.println(findLogerStr(a, b));
}
}
public static String findLogerStr(String str1, String str2) {
String longStr = null;
String shortStr = null;
if (str1.length() > str2.length()) {
longStr = str1;
shortStr = str2;
} else {
longStr = str2;
shortStr = str1;
}
int start = 0;
int end = 0;
for (int i = 0; i < shortStr.length(); i ++) {
for (int j = shortStr.length(); j > i; j--) {
String temp = shortStr.substring(i, j); // 从最长的子串开始截取
if (longStr.contains(temp) && (end - start < j - i)) {
start = i;// 找到长的更新首尾两个指针
end = j;
}
}
}
return shortStr.substring(start, end);
}
}