分治策略有一种“大事化小,小事化了”的境界,它的思想是将原问题分解成两个子问题,两个子问题的性质和原问题相同,因此这两个子问题可以再用分治策略求解,最终将两个子问题的解合并成原问题的解。有时,我们会有这样的疑惑:分治策略是将原问题分解成子问题,子问题又用分治策略求解,那分治策略到底是什么?这种感觉就像听到有人说“因为我说我没有做错事,所以我没有做错事”一样,让我们不知道他“没有做错事”的真正原因是什么。

对于上面的困惑,我本科的老师告诫过我们:“对于分治策略,当你们想不明白的时候只需记住两点:一是怎样将问题分解成两个子问题,二是要有递归出口。”举个小例子:八个小伙伴为确定谁是领头,决定比武论,两两比较,胜者将进入下一轮再进行两两比较,最终将决出一个领头,如果我们将这个思路倒过来想就是分治策略了,八个人分成两组,此时每组四人,每组决出一个领头,再比较这两个组的领头就能决出最终那个领头,而每组领头的决出又采用将该组分成两组,每组两人,这时直接比较就能决出领头的,无需再分,此处就是递归的出口。说了这么多,总结一下分治策略的步骤:

  1. 如果问题规模足够小,那么采取方法解决它;否则,继续将问题划分为两个子问题(小事化了)
  2. 对于子问题仍采用分治策略(大事化小)
  3. 将子问题的解合并成原问题的解(特别注意)

第一步、第二步是思维的问题,只要我们不陷入思维的漩涡,记住处理递归出口就没有问题,而第三步是细节问题,我们常常忽略,而且不易处理,下面举两个例子来加以说明。

求二维极大点问题。在二维空间中,如果x1>x2且y1>y2,那么称点(x1,y1)支配点(x2,y2)。在一个二维点集中,如果一个点没有被其它点支配,则称这个点是极大点。为了找出这个点集的所有极大点,可以采用分治策略,将点集划分成点数更少的两个点集,递归出口是:当点集只有一个点时,这个点就是这个点集的极大点。对于合并子问题的解的时候就要小心了,并不是简单地取它们的并集,而要考虑这两个点集的极大点之间是否存在支配与被支配的关系,处理的方法很简单:如果左子点集的极大点的y值小于右子点集中的某个极大点,则舍弃左子点集的该极大点。

最近点对问题:一个平面上有n个点,找出距离最近的那对点。采用分治策略,第一二步就不说了。当我们合并这个子点集的最近点对时需要注意:原点集的最近点对的两个端点可能在不同的子点集中,这就需要我们考虑,以分割线附近的点为圆心,以两子点集较小的点对的距离为半径画圆,判断圆内是否存在另个点集中的点,如果存在,最短距离将更改,如果没有,最短距离就是两子点集较小的点对的距离。

在大学老师告诫我们的两点,加上合并注意事项,就构成了采用分治策略应注意的三点:

  1. 思考如何将大问题分解成两个小问题
  2. 记住递归出口
  3. 处理合并解的问题

【技术文档】《算法设计与分析导论》R.C.T.Lee等·第4章 分治策略相关推荐

  1. 【技术文档】《算法设计与分析导论》R.C.T.Lee等·第6章 剪枝搜索方法

    读到"剪枝搜索方法"这个标题,不禁让我想到剪枝搜索方法与分枝限界策略有什么不同?它们的字面意思不都是减少分枝吗?带着这样的疑问,我学习了剪枝搜索方法,以及区分剪枝搜索方法与分治策略 ...

  2. 《大数据算法》一1.3 大数据算法设计与分析

    本节书摘来华章计算机<大数据算法>一书中的第1章 ,第1.3节,王宏志 编著, 更多章节内容可以访问云栖社区"华章计算机"公众号查看. 1.3 大数据算法设计与分析 本 ...

  3. 算法设计与分析:贪心算法 - 排课问题(DP与贪心的区别与应用)

    文章目录 前言 贪心算法概念 排课问题 问题描述与分析 动态规划求解 简化问题应用贪心算法 总结 本文参考UCAS卜东波老师算法设计与分析课程撰写 前言 前面两大章节的内容分治思想与动态规划暂时告一段 ...

  4. 十三种技术文档模板_竞品分析|关于产品规划的思考:石墨文档 VS 腾讯文档 VS金山文档...

    作者以在线协作文档行业领先的石墨文档.腾讯文档和金山文档为例进行了了竞品分析,通过对几款产品全方位的分析,总结了自己关于石墨文档产品规划的思考. 一.竞品概述 1. 竞品目的 2. 竞品目的 通过对石 ...

  5. 算法设计与分析 课程设计之N皇后问题

    题目 N皇后回溯法求解空间 目的要求 目的: 1.用学到的书本知识解决实际问题的能力: 2.锻炼实际工作所需要的动手能力: 3.加强对数据结构和算法的应用: 4.锻炼自己以科学理论和工程上能力的技术, ...

  6. 需求文档和设计文档的区别

    需求文档和设计文档的区别 需求文档是根据用户需求转化而来的技术实现需求,需要针对用户提出的产品目标进行细分,总结出具体的每一个功能点,再针对每一个功能点细分为各种不同的操作流程,对每一个操作流程进行技 ...

  7. 良心之作!超过 10000+ 的互联网团队正在使用的在线 API 文档、技术文档工具

    搞开发的同学都知道一个好的 API 文档是有多重要! 每当接手一个别人开发好的项目,看着那些没有注释的代码,真的头大. 程序员都很希望别人能写技术文档,因为可以提高自己开发的效率,而往往自己却很不希望 ...

  8. 这谁写的技术文档?我想锤死他...

    点击上方"朱小厮的博客",选择"设为星标" 后台回复"书",获取 后台回复"k8s",可领取k8s资料 很多技术人自己非 ...

  9. 计算机算法设计与分析读后感,算法设计与分析基础经典读后感有感

    <算法设计与分析基础>是一本由Anany levitin著作,清华大学出版社出版的胶版纸图书,本书定价:49.00元,页数:409,特精心从网络上整理的一些读者的读后感,希望对大家能有帮助 ...

最新文章

  1. [Python技巧]是时候用 defaultdict 和 Counter 代替 dictionary 了
  2. spring aop设计模式_Spring框架中设计模式的运用
  3. hibernate面试问题_Hibernate面试问答
  4. fork函数结果分析
  5. 百科不全书之Python进阶
  6. EditPlus 快捷键大全
  7. matlab imshow伪彩色,实验7:彩色图像及伪彩色处理
  8. [HDU6070] Dirt Ratio
  9. Flann特征点匹配简述(Lowe's algorithm)
  10. 关于intelCPU缓存行,以及伪共享问题
  11. 这年头,当帅哥不容易呀!!
  12. 小白学习,歌词解析(全)
  13. cocos2dx使用了第三方库照样移植android平台-解决iconv库的移植问题
  14. CATT在SAP系统中的应用
  15. 计算机系统软件最核心最重要,计算机软件系统最重要的是(),它是计算机能正常工作的核心。 - 问答库...
  16. IOS之RSA加密解密与后台之间的双向加密详解
  17. TCP/IP体系结构
  18. php简易在线投票系统,ThinkPHP 框架 简易投票系统
  19. 2021北京交通大学计算机专硕复试经验分享
  20. Go语言生成GUID和UUID

热门文章

  1. win10 全屏秒退
  2. lerna使用初体验
  3. 小程序 选择地区(地区选择器)
  4. 华硕主板Z97-A无法识别intel M.2 NVME固态硬盘的解决方案
  5. Vue爬坑之路 二:使用Muse-UI前端框架及axios,实现简单登录页
  6. 淘宝天猫价格监控接入方案
  7. 高版本Ubuntu(如22.02)修改apt源,快速安装低版本gcc/g++
  8. matlab epics,基于EPICS/MATLAB图像处理的光束位置测量系统
  9. Easy-x的基础教程使用介绍
  10. Latex、如何将word中的表格转换为Latex代码