寻找所有元素都必须用到的子集组合
给定一个数组 [a],如何生成满足以下条件的一系列子集组合:
示例:
, b, c]]解决方法:
我们可以使用如下步骤解决这个问题:
代码示例:
const arr = ['a', 'b', 'c'];
// 获取所有子集
const generatesubsets = (arr, subset = [[]]) => {
if (arr.length === 0) {
return subset;
} else {
const current = arr[0];
const newsubset = [];
subset.foreach(sub => {
newsubset.push(sub.concat(current), sub);
});
return generatesubsets(arr.slice(1), newsubset);
}
};
// 生成子集的差集
const generatediffsets = (arr, b) => {
let result = [];
for (let i = 0; i < b.length / 2; i++) {
const diffs = arr.filter(v => b[i].indexof(v) == -1);
result.push([b[i], diffs]);
}
// 添加单项子集
const single = arr.map(i => [i]);
result.push(single);
return result;
};
const subsets = generatesubsets(arr);
const results = generatediffsets(arr, subsets);
console.log(results);输出:
[[['A'], ['B', 'C']], [['B'], ['A', 'C']], [['C'], ['A', 'B']], [['A', 'B'], ['C']], [['A', 'C'], ['B']], [['B', 'C'], ['A']], [['A', 'B', 'C']]]