This commit is contained in:
parent
7e43421a71
commit
4d93e5a150
@ -39,7 +39,7 @@ void main(void) {
|
||||
dfs(curNode->right, result);
|
||||
```
|
||||
|
||||
data:image/s3,"s3://crabby-images/ddac8/ddac863ee2352bd202de2d2edccd6bf450fad53c" alt="begin"
|
||||
data:image/s3,"s3://crabby-images/65693/6569330be33411af2e55b9933aea921f55089440" alt="begin"
|
||||
|
||||
中序遍历:
|
||||
|
||||
@ -49,7 +49,7 @@ void main(void) {
|
||||
dfs(curNode->right, result);
|
||||
```
|
||||
|
||||
data:image/s3,"s3://crabby-images/014f4/014f417b5dc84b68041974113246e0ec574842c4" alt="medium"
|
||||
data:image/s3,"s3://crabby-images/967bd/967bd98d86ba960fd269586c94e13cff7e09c03d" alt="medium"
|
||||
|
||||
后序遍历:
|
||||
|
||||
@ -59,7 +59,7 @@ void main(void) {
|
||||
printf("%d\n", curNode->val);
|
||||
```
|
||||
|
||||
data:image/s3,"s3://crabby-images/1eec7/1eec745fed27f8571f4e01c32598ff45e1dbb150" alt="end"
|
||||
data:image/s3,"s3://crabby-images/dd5e2/dd5e2f728672db148792adc2274c312174f57f46" alt="end"
|
||||
|
||||
## 深度优先遍历(迭代法)
|
||||
|
||||
|
@ -4,7 +4,7 @@
|
||||
|
||||
## [77. 组合](https://leetcode.cn/problems/combinations/description/)
|
||||
|
||||
data:image/s3,"s3://crabby-images/c2324/c2324b69004f3da4fe354f9c9724fa62102b8e47" alt="combinations"
|
||||
data:image/s3,"s3://crabby-images/c8838/c88387987e53aa061f63497df920a1632f09c151" alt="combinations"
|
||||
|
||||
每个节点存储的数据是什么?是一个 `vector<int>` 类型的数据,代表当前节点的路径。
|
||||
|
||||
@ -43,7 +43,7 @@ void combineDFS(int n, int k, int begin, vector<int> &path,
|
||||
|
||||
我们现在来看看能不能优化。
|
||||
|
||||
data:image/s3,"s3://crabby-images/fa0e1/fa0e17deb32864619d024bf503ae86d68768dbf1" alt="optimization"
|
||||
data:image/s3,"s3://crabby-images/22297/22297e395209bc165050f2ce1df5c1b8a74d881c" alt="optimization"
|
||||
|
||||
在上图的这种情况中,每一层其实都可以剪掉一些不可能的分支,我们可以对每一层循环的终止条件进行限制,从而剪枝。
|
||||
|
||||
@ -98,7 +98,7 @@ Output:
|
||||
|
||||
正确的逻辑应该是如果 `candidates[i] == candidates[i - 1]` 且 `candidates[i - 1]` 使用过,则剪枝。
|
||||
|
||||
data:image/s3,"s3://crabby-images/bbd73/bbd73824074f46b5159bafb76d36f69976251c32" alt="demo"
|
||||
data:image/s3,"s3://crabby-images/cd18b/cd18b2118d24b9b9f0c24ac6cd0ded7552a4b5f8" alt="demo"
|
||||
|
||||
那么我们现在要来定义一下什么叫“使用过”。这张图里面有两种“使用过”,第一种使用过是“在树枝上使用过”,第二种使用过是“在数层上使用过”。
|
||||
|
||||
|
@ -88,4 +88,4 @@ vector<vector<int>> S0047::permuteUnique(vector<int> &nums) {
|
||||
|
||||
这道题本来是想不到回溯法的,但是如果某道题能够拆分成多个步骤,每个步骤都在前一步的基础上进行选择,那么就可以用回溯法。
|
||||
|
||||
data:image/s3,"s3://crabby-images/26b82/26b8211c48edf37f133f9378b59eab60eccb634d" alt="demo"
|
||||
data:image/s3,"s3://crabby-images/ce5a8/ce5a885d60b0c43eb79bdc591e38748f7a436e8d" alt="demo"
|
||||
|
@ -4,6 +4,6 @@
|
||||
|
||||
## [131. 分割回文串](https://leetcode.cn/problems/palindrome-partitioning/)
|
||||
|
||||
data:image/s3,"s3://crabby-images/388c2/388c2aaedd2851d06b0d0d661571819f090daa21" alt=""
|
||||
data:image/s3,"s3://crabby-images/f509b/f509b56a7b7449b0cf8a8f1604ccf117f5410497" alt=""
|
||||
|
||||
## [93. 复原 IP 地址](https://leetcode.cn/problems/restore-ip-addresses/)
|
||||
|
@ -1,6 +1,6 @@
|
||||
#include "s0008_string_to_integer.hpp"
|
||||
|
||||
// 当流程很复杂的时候,画流程图: https://paste.sainnhe.dev/NQxx.png
|
||||
// 当流程很复杂的时候,画流程图: https://share.sainnhe.dev/NQxx.png
|
||||
|
||||
class S0008Automaton {
|
||||
string state = "start";
|
||||
|
Loading…
x
Reference in New Issue
Block a user