我正在尝试解决编码挑战“组合总和”(https://leetcode.com/problems/combination-sum/discuss/127208/Simple-Javascript-Solution)并找到了解决方案,但我无法理解为什么currArr.pop()
内if (target >= candidates[i])
是必需的。我试图理解通过删除它并替换它但仍然无法弄明白。有人可以解释为什么这对我来说是必要的吗?谢谢!
var combinationSum = function(candidates, target) {
candidates.sort((a,b) => a - b);
const results = [];
const innerFunction = (currArr, target, index) => {
if (target === 0) {
results.push(currArr.slice());
return;
}
for (let i = index; i < candidates.length; i++) {
if (target >= candidates[i]) {
const newTarget = target - candidates[i];
currArr.push(candidates[i]);
innerFunction(currArr, newTarget, i);
currArr.pop();
} else {
return;
}
}
}
innerFunction([], target, 0);
return results;
};
console.log(combinationSum([2,3,6,7], 7));
答案 0 :(得分:1)
这种技术称为回溯。 回溯是一种用于逐步建立问题解决方案的技术。这些&#34;部分解决方案&#34;可以用一系列决定来表达。一旦确定一个&#34;部分解决方案&#34;是不可行的(即后续决定不能将其转换为解决方案)然后回溯算法将其步骤回溯到最后可行的部分解决方案&#34;再试一次。
这里的关键点是在currArr.push(candidate [i])之后流是recurcion调用innerFunction(currArr,newTarget,i);所以currArr不断增长,在某些时候,如果(目标=== 0)找到了所需的结果,你用currArr.slice()对你的currArr进行深度复制,现在返回,代码又回到了currArr.pop( )因为这是在innerFunction递归调用之后发生的。
我希望这可以帮助你 - )