糊秃秃
糊秃秃
全部文章
题解
归档
标签
去牛客网
登录
/
注册
糊秃秃的博客
全部文章
/ 题解
(共5篇)
深度优先搜索
深度优先搜索具体操作是在得到一个新节点时立即遍历该新节点相邻的节点, 这样又得到一个新节点, 同理. 需要注意的是, 遍历过的节点不能被再次遍历. 如下: 从节点 0 出发开始遍历, 得到到新节点 6 时, 立马对新节点 6 进行遍历, 得到新节点 4; 如此反复以这种方式遍历新节点, 直到没...
dfs
深度优先遍历
leetcode
2020-02-21
0
709
广度优先搜索
广度优先搜索具体操作是一层一层地进行遍历, 每层遍历都是以上一层遍历到的节点作为起点, 遍历其能访问到的所有节点. 需要注意的是, 遍历过的节点不能被再次遍历. 如下: 第一层: 0 -> {6, 2, 1, 5}; 第二层: 6 -> {4}; 2 -> {}; 1 -&...
leetcode
广度优先遍历
bfs
2020-02-21
0
746
插入排序
插入排序过程中,序列分为已遍历部分和未遍历部分,已遍历序列有序,未遍历序列有序性未知,为了做到这一点,在每遍历每一个数时O(n),依次在已遍历序列中从后往前比较O(n),将当前数放入适当位置,直至未遍历部分为空O(n ^ 2)。相当于摸牌将牌组分为,手中的牌和牌组中的牌,手中的牌有序,牌组中的牌有序...
剑指offer
快速排序
insert
2019-08-23
4
1242
快速排序
快速排序也是使用分治策略,用partition函数将序列一分为二(O(n))后,将子序列递归排序((1 / n) * ∑[T(k) + T(n - k - 1)]),最后合并有序子序列(O(1)),T(n) = O(n) + (1 / n) * ∑[T(k) + T(n - k - 1)] = O(...
剑指offer
快速排序
partition
2019-08-22
3
1478
归并排序
归并排序使用分治策略,序列一分为二(O(1))后,将子序列递归排序(2 * T(n / 2)),最后合并有序子序列(O(n)),T(n) = 2 * T(n / 2) + O(n) = O(n * logn)。 一、归并排序 1、归并排序的实现 写递归函数就像开车,先系上安全带即先写出递归基。 pu...
剑指offer
归并排序
merge
2019-08-22
0
2561