Я хочу изменить следующее решение динамического программирования на проблему чередования двух строк.Я хочу напечатать индексы строки-3, которые равны строке-1, если приведенный ниже код возвращает значение true.
Пример:
- str1: STOVE
str2: ackrflow
str3: STackOVErflow
str3 является чередованной строкой str1 и str2, поэтому возвращает true.
ТЕПЕРЬ, он должен напечатать индексы, например:
"0,1,5,6,7", для индексов в str3, которые обозначают "печь".
public boolean isInterleaved(char str1[], char str2[], char str3[]){
boolean T[][] = new boolean[str1.length +1][str2.length +1];
if(str1.length + str2.length != str3.length){
return false;
}
for(int i=0; i < T.length; i++){
for(int j=0; j < T[i].length; j++){
int l = i + j -1;
if(i == 0 && j == 0){
T[i][j] = true;
}
else if(i == 0){
if(str3[l] == str2[j-1]){
T[i][j] = T[i][j-1];
}
}
else if(j == 0){
if(str1[i-1] == str3[l]){
T[i][j] = T[i-1][j];
}
}
else{
T[i][j] = (str1[i-1] == str3[l] ? T[i-1][j] : false) || (str2[j-1] == str3[l] ? T[i][j-1] : false);
}
}
}
return T[str1.length][str2.length];
}