문자열 배열을 받는 JavaScript 함수를 작성해야 합니다. 함수는 배열에 존재하는 모든 하위 문자열과 상위 문자열 조합을 찾아 해당 요소의 배열을 반환해야 합니다.
예를 들어 - 배열이 -
인 경우const arr = ["abc", "abcd", "abcde", "xyz"];
그러면 출력은 다음과 같아야 합니다. -
const output = ["abc", "abcd", "abcde"];
처음 두 개는 마지막 부분 문자열이기 때문입니다.
예시
이에 대한 코드는 -
const arr = ["abc", "abcd", "abcde", "xyz"];
const findStringCombinations = (arr = []) => {
let i, j, res = {};
for (i = 0; i < arr.length - 1; i++) {
if (res[arr[i]]) {
continue;
};
for (j = i + 1; j < arr.length; j++) {
if (res[arr[j]]) {
continue;
}
if (arr[i].indexOf(arr[j]) !== -1 || arr[j].indexOf(arr[i]) !== -1) {
res[arr[i]] = true;
res[arr[j]] = true;
}
};
};
const result = arr.filter(el => res[el]);
return result;
};
console.log(findStringCombinations(arr)); 출력
콘솔의 출력은 -
[ 'abc', 'abcd', 'abcde' ]