贪心算法 data:image/s3,"s3://crabby-images/86d40/86d405428bd5af0301c3acb25ec6510f22f3eca4" alt="在这里插入图片描述" 只顾当前最优,贪心算法在很多情况下,是不适用的。生活中的实际问题,不能处处只看眼前。 data:image/s3,"s3://crabby-images/68559/68559d9c0483f0e0623973692b5a04225147b9a8" alt="在这里插入图片描述" 举例:最少纸币问题 data:image/s3,"s3://crabby-images/0f061/0f0613c929c119ad9757e0e754d51f888ef06d57" alt="在这里插入图片描述" 当问题可以拆分成子问题,子问题有最优解时,可以用贪心算法。 这种子问题最优解成为最优子结构。 data:image/s3,"s3://crabby-images/2d2c9/2d2c94c39ef29182689df91474ebe63af17a4f80" alt="在这里插入图片描述" 动态规划就是子问题不一定选择最优解,而是多选几种可能,存起来所有可能的解。贪心算法无法回退,动态规划保存了之前的结果,有回退的功能。 实战 122. 买卖股票的最佳时机 II https://leetcode-cn.com/problems/best-time-to-buy-and-sell-stock-ii/ data:image/s3,"s3://crabby-images/f0e3c/f0e3c5e8271aa9e2821f52cc9c5473bfd6883959" alt="在这里插入图片描述" 广度优先搜索 data:image/s3,"s3://crabby-images/39a25/39a2538aa1d57b784c0c14d6b3d86cb026f52929" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/7a764/7a76451613e85b6896320d46a15040ac9c4bd5f9" alt="在这里插入图片描述" 这个理解为魂斗罗里面的散弹枪 data:image/s3,"s3://crabby-images/d8289/d828989f33d9cb913abfa5c0970c5052ab0e6b89" alt="在这里插入图片描述" 本质上是把根节点和儿子节点依次加入到队列queue中。先进先出。 1先进来,然后1出去,放1的儿子2,3,4.然后2 出去,放2的儿子5,3的儿子6,7,4的儿子8。然后5出去,放5的儿子9。6出去,放6的儿子10.
BFS不需要递归,而是用一个queue来进行。 data:image/s3,"s3://crabby-images/e4142/e414225ac208928f789bbc317bdfb2e7f33038df" alt="在这里插入图片描述" visited的作用就是判定是否已经访问过了,不然的话,可能会成为环。就是图,而不是二叉树了。
深度优先搜索:广度优先更符合人的思维,深度优先更符合计算机的思维,就是用statck栈。 data:image/s3,"s3://crabby-images/a24af/a24af6ab23feeb8250ef275a00e808c3fd91bc62" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/51160/511601c8adab03eb82c7e9393cf7363a37e04e5d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/62994/629947f0ddd029095792965a25bb17f52e845e5d" alt="在这里插入图片描述" BFS和DFS比较: BFS地毯式推进,DFS一条路走到黑,不撞南墙不回头。 data:image/s3,"s3://crabby-images/4cd6e/4cd6e22b274d9df6901e662dd77b5169ebb16c76" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/98e83/98e83b9f17cd8a12f25f2bb611645b263c51e8f0" alt="在这里插入图片描述" stack栈是先入后出,这里面的递归就是实现了stack的作用。 DFS非递归写法:不常用,手动实现stack。 data:image/s3,"s3://crabby-images/d8674/d867410af1bcb78ad79147a98f550bc3bd174069" alt="在这里插入图片描述" 实战 102. 二叉树的层序遍历 https://leetcode-cn.com/problems/binary-tree-level-order-traversal/ data:image/s3,"s3://crabby-images/19e9a/19e9adf802b9c8a551d84226046b6298789fcb7f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/217c4/217c4ca4efae8f493dbf4b3c0fe40e7e6b45c971" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/56771/56771bc63d53a80bcd529a8a4efe685ad001ba28" alt="在这里插入图片描述" 104. 二叉树的最大深度 https://leetcode-cn.com/problems/maximum-depth-of-binary-tree/ data:image/s3,"s3://crabby-images/b0df7/b0df7da998825b7308cfd8233732d256fed92b5b" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/6f590/6f590fd721e003aa05d2b6994cb2245c35537ffb" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/8a905/8a90583296c2a3a7ef1d1b19f1c4ad592685528f" alt="在这里插入图片描述" 实战 22. 括号生成 https://leetcode-cn.com/problems/generate-parentheses/ data:image/s3,"s3://crabby-images/f1024/f1024569d978df3fe87fe202727cdae4627b2ba7" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/e3e5f/e3e5f5a65a9c2811ae8371cba9fa7b32b1a5ce29" alt="在这里插入图片描述"
|