算法学习之分治法

分治法,顾名思义就是分而治之,即把问题拆解为性质相同的小问题再处理。

做了一些题后发现,分治法除了分治,名字里还少了一步,那就是合,也就是怎样通过小问题的答案得到拆分之前大问题的答案。

分治法的时间复杂度:分治法并没有像二分法一样每次丢掉一半无用的解,它只是做了分离,而分离的两部分都是需要处理的,所以分治法的时间复杂度是O(n)。特例情况是当分离的两部分继续分治处理出现重复计算的情况时,就会比O(n)大了!所以请确保你的分治尽量不要出现重叠计算的情况。

那么什么问题适合用分治的思想解决呢?二叉树!二叉树这种左右子树的结构天生就非常适合分治,所以它的大部分问题都能用分治解决,碰到一个问题你只需要问问左子树你怎么处理,右子树你怎么办,得到左右子树的答案后,你再想想最后的答案是个啥~除了二叉树,快速排序归并排序这两个著名的排序算法也是分治的思想。下面就举几个解题的例子来加深一下对分治法的学习。

1、前序遍历二叉树


Paste_Image.png

2、求二叉树的最大路径和
给一棵二叉树,找出从根节点出发的路径中,和最大的一条。
这条路径可以在任何二叉树中的节点结束,但是必须包含至少一个点。


Paste_Image.png

3、求最近公共祖先
给定一棵二叉树,找到两个节点的最近公共父节点(LCA),给出的两个节点都在树中存在。


Paste_Image.png

4、快速排序
这里我就偷个懒,直接贴出百度百科上给的php标准答案~


Paste_Image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 树的概述 树是一种非常常用的数据结构,树与前面介绍的线性表,栈,队列等线性结构不同,树是一种非线性结构 1.树的定...
    Jack921阅读 9,988评论 1 31
  • 1 序 2016年6月25日夜,帝都,天下着大雨,拖着行李箱和同学在校门口照了最后一张合照,搬离寝室打车去了提前租...
    RichardJieChen阅读 10,639评论 0 12
  • 此笔记用于指导初学者阅读。原文在此!,出于便于交流的考虑,内容重放在此。由于作业部落支持LaTex公式,所以,更加...
    Bintou老师阅读 14,241评论 0 27
  • 参考两篇其他bolg总结的二叉树:https://github.com/xy7313/lintcode/blob/...
    暗黑破坏球嘿哈阅读 7,102评论 0 1
  • 1. 链表 链表是最基本的数据结构,面试官也常常用链表来考察面试者的基本能力,而且链表相关的操作相对而言比较简单,...
    Mr希灵阅读 5,352评论 0 20

友情链接更多精彩内容