문자열을 입력받아 각 문자를 가지고 만들 수 있는 모든 부분집합을 리턴해야 한다.
주의사항
입출력 예시
let output1 = powerSet('abc');
console.log(output1); // ['', 'a', 'ab', 'abc', 'ac', 'b', 'bc', 'c']
let output2 = powerSet('jjump');
console.log(output2); // ['', 'j', 'jm', 'jmp', 'jmpu', 'jmu', 'jp', 'jpu', 'ju', 'm', 'mp', 'mpu', 'mu', 'p', 'pu', 'u']
arr
arr
배열의 요소를 하나씩 순회하면서 문제의 조건에서 사전식 순서로 정렬되어야한다고 했기 때문에 마지막에 부분집합 배열을 정렬해서 반환한다.
const powerSet = function (str) {
const arr = Array.from(new Set(str)).sort()
let set = [""];
for (let i = 0; i < arr.length; i++) {
let len = set.length;
for (let j = 0; j < len; j++) {
set.push(set[j] + arr[i]);
}
}
return set.sort();
};
레퍼런스 코드에서는 재귀를 사용해서 풀었다.
const powerSet = function (str) {
// 정렬
const sorted = str.split('').sort();
// 중복 제거
const deduplicated = sorted.reduce((acc, item) => {
if (acc[acc.length - 1] === item) {
return acc;
} else {
return acc.concat(item);
}
});
let subSets = [];
const pickOrNot = (idx, subset) => {
// base case
if (idx === deduplicated.length) {
// 마지막 문자까지 검토한 경우
subSets.push(subset);
return;
}
// recursive case
// idx번째 문자가 포함되지 않는 경우
pickOrNot(idx + 1, subset);
// idx번째 문자가 포함되는 경우
pickOrNot(idx + 1, subset + deduplicated[idx]);
};
pickOrNot(0, '');
return subSets.sort();
};