さて、私の問題は次のとおりです。指定された 2 つの文字列間のより大きなシーケンスのサイズを返す必要があります。
現時点での私のコード:
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(
new InputStreamReader(System.in));
while (true) {
String word1 = br.readLine();
if (word1 == null) {
break;
}
String word2 = br.readLine();
int lengthWord1 = word1.length();
int lengthWord2 = word2.length();
int max = 0;
if (word1.equals(word2) || word2.contains(word1)) {
max = lengthWord1;
} else if (word1.contains(word2)) {
max = lengthWord2;
} else {
int j = 1;
int maxLength = Math.max(lengthWord1, lengthWord2);
int counter = 0;
String largerWord;
String smallestWord;
if (maxLength == lengthWord1) {
largerWord = word1;
smallestWord = word2;
} else {
largerWord = word2;
smallestWord = word1;
}
int minLength = smallestWord.length();
int oldMax = 0;
for (int i = 0; i < maxLength - 1; i++) {
while (maxLength + 1 != j) {
String x = largerWord.substring(i, j++);
int lengthOfReplace = smallestWord
.replace(x, "").length();
if (minLength == lengthOfReplace) {
if (max != 0) {
i = counter;
if (smallestWord.contains(
x.substring(x.length() - 1))) {
i--;
}
}
break;
}
max = Math.max(minLength - lengthOfReplace, oldMax);
counter++;
oldMax = max;
}
}
}
System.out.println(max);
}
}
いくつかの入力と期待される出力:
- abcdef cdofhij // 2 (ペア ("cd")
- TWO FOUR // 1 (文字「O」)
- abracadabra open // 0 (なし)
- ねえ、この Java はいいね Java は新しいパラダイム // 7 ("ava is ")
上記のすべての入力は私のコードで完全に機能していますが、場合によってはまだ失敗しています (文字が重複しているためか、わかりません)。
誤った出力の例:
- abXabc abYabc // 3 を出力するはずですが、4 を返します
だから、私は今立ち往生しています、どんな助けも大歓迎です。