来老铁干了这碗代码 2020-03-03 16:14 采纳率: 75%
浏览 672
已采纳

回溯、深搜、剪枝的区别是什么?

在刷题中,看题解时总是遇到DFS、回溯、剪枝这类字眼,但总是搞不懂他们有什么区别。

以下是我的理解,不知是否正确?

剪枝是用来优化的,深搜是将一种可能执行到底,而回溯是碰到不可行的情况就结束,开始下次遍历, 那么深搜+剪枝=回溯。

  • 写回答

1条回答 默认 最新

  • 格戮 2020-03-03 17:57
    关注

    以下是我个人理解:

    深搜可以理解为一直套用函数最后得出结果;

    回溯可以理解为对每一步或每一个位置上的不同操作的出多种结果,再根据所需取得想要的答案;

    剪枝就是对递归函数空间和时间上的优化,舍掉无用部分的递归,尽力去只递归有价值部分。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?