mirror of
https://github.com/huihut/interview.git
synced 2024-03-22 13:10:48 +08:00
添加广度优先搜索、深度优先搜索、分治法、动态规划、贪心法
This commit is contained in:
parent
0cd1cfa7e2
commit
17cdac72d1
15
README.md
15
README.md
|
@ -1695,6 +1695,21 @@ typedef struct BiTNode
|
|||
2-3树 | O(log<sub>2</sub>n - log<sub>3</sub>n) | |
|
||||
B树/B+树 |O(log<sub>2</sub>n) | |
|
||||
|
||||
### 图搜索算法
|
||||
|
||||
图搜索算法 |数据结构| 遍历时间复杂度 | 空间复杂度
|
||||
---|---|---|---
|
||||
[BFS广度优先搜索](https://zh.wikipedia.org/wiki/%E5%B9%BF%E5%BA%A6%E4%BC%98%E5%85%88%E6%90%9C%E7%B4%A2)|邻接矩阵<br/>邻接链表|O(\|v\|<sup>2</sup>)<br/>O(\|v\|+\|E\|)|O(\|v\|<sup>2</sup>)<br/>O(\|v\|+\|E\|)
|
||||
[DFS深度优先搜索](https://zh.wikipedia.org/wiki/%E6%B7%B1%E5%BA%A6%E4%BC%98%E5%85%88%E6%90%9C%E7%B4%A2)|邻接矩阵<br/>邻接链表|O(\|v\|<sup>2</sup>)<br/>O(\|v\|+\|E\|)|O(\|v\|<sup>2</sup>)<br/>O(\|v\|+\|E\|)
|
||||
|
||||
### 其他算法
|
||||
|
||||
其他算法 |思想| 应用
|
||||
---|---|---
|
||||
[分治法](https://zh.wikipedia.org/wiki/%E5%88%86%E6%B2%BB%E6%B3%95)|把一个复杂的问题分成两个或更多的相同或相似的子问题,直到最后子问题可以简单的直接求解,原问题的解即子问题的解的合并|[循环赛日程安排问题](https://github.com/huihut/interview/tree/master/Problems/RoundRobinProblem)、排序算法(快速排序、归并排序)
|
||||
[动态规划](https://zh.wikipedia.org/wiki/%E5%8A%A8%E6%80%81%E8%A7%84%E5%88%92)|通过把原问题分解为相对简单的子问题的方式求解复杂问题的方法,适用于有重叠子问题和最优子结构性质的问题|[背包问题](https://github.com/huihut/interview/tree/master/Problems/KnapsackProblem)、斐波那契数列
|
||||
[贪心法](https://zh.wikipedia.org/wiki/%E8%B4%AA%E5%BF%83%E6%B3%95)|一种在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是最好或最优的算法|旅行推销员问题(最短路径问题)、最小生成树、哈夫曼编码
|
||||
|
||||
## Problems
|
||||
|
||||
### Single Problem
|
||||
|
|
Loading…
Reference in New Issue
Block a user