数据结构与算法-算法的设计模式

贪心算法

在会有多次处理得出结果的情况下,对于每一次处理,都选最接近目标的解。也就是对于每一次的局部,都选择最优解。
譬如: 你有 1、2、5、10 元各五张,你要给别人四十七块钱,如何使给的钞票最少?
就是4张十块,1张五块,1张两块。

【注意:贪心算法虽然每次都是最最优解,但是对于整体不一定就是最优解。因为它都是针对每一次的局部】
贪心算法是对结果没有严格要求,甚至说不能提前预知结果,上一次选择对下一次有影响,是一个动态的算法,确保每次的动态中都能选择最好的,已达到最终结果尽可能更好。

分治算法

分治算法(divide and conquer)的核心思想其实就是四个字,分而治之 ,也就是将原问题划分成 n 个规模较小,并且结构与原问题相似的子问题,递归地解决这些子问题,然后再合并其结果,就得到原问题的解。
这里可以看出,分治和递归其实是差不多的,那么他们到底有啥区别呢?
分治算法是一种处理问题的思想,递归是一种编程技巧。也就是递归是一种编程层面的落地方案。

分治思想在海量数据处理中的应用

当我们面临大数据量的时候,文件比内存大,又需要进行运算。此时我们可以将大文件分割成多个小文件,对小文件进行运算,再合并小文件的结果,再对结果进行运算。
从上述操作来变种,那我们是不是可以分布到多台机器上运算。这种思想就能把一个大问题,分解到很多个小解上。让很多机器来跑每一个小解,然后组合成最终解。

如果我们要处理的数据是 1T、10T、100T 这样子的,那一台机器处理的效率肯定是非常低的。而对于谷歌搜索引擎来说,网页爬取、清洗、分析、分词、计算权重、倒排索引等等各个环节中,都会面对如此海量的数据(比如网页)。所以,利用集群并行处理显然是大势所趋。

一台机器过于低效,那我们就把任务拆分到多台机器上来处理。如果拆分之后的小任务之间互不干扰,独立计算,最后再将结果合并。这不就是分治思想吗?

实际上,MapReduce 框架只是一个任务调度器,底层依赖 GFS 来存储数据,依赖 Borg 管理机器。它从 GFS 中拿数据,交给 Borg 中的机器执行,并且时刻监控机器执行的进度,一旦出现机器宕机、进度卡壳等,就重新从 Borg 中调度一台机器执行。
这种思想设计出来的处理方案也就是并行计算框架。

回溯算法

对需要多次处理的情况下,对每一次的可能性都进行尝试。所以就是从最外层开始往里尝试。最终就对所有可能都有进行尝试。其实也就是穷举了所有情况。比如说图的深度优先搜索。

对于具体业务的回溯,我们其实是可以根据业务情况对回溯进行优化的,有某些情况是明显不会符合业务要求的,我们可以不回溯。

回溯算法的思想非常简单,大部分情况下,都是用来解决广义的搜索问题,也就是,从一组可能的解中,选择出一个满足要求的解。回溯算法非常适合用递归来实现,在实现的过程中,剪枝操作是提高回溯效率的一种技巧。利用剪枝,我们并不需要穷举搜索所有的情况,从而提高搜索效率。

动态规划

动态规划实际上就是每次执行都记录执行要素和执行结果,维系一个执行记录表,每一次执行的时候先跟执行记录表进行对照,有就直接利用其结果,对结果进行判断,进而确定之后该怎么执行。这样就能舍弃很多错误执行过程。因为执行记录表是动态的,所以这种方式叫动态规划。

其实也就是 把问题分解成很多子问题,且子问题具有包含性,例如,当求出子子问题的最优解的时候,求子问题的最优解时,就只需要把当前问题的节点数据与子子问题的最优解进行处理,就可以了。

动态规划比较适合用来求解最优问题,比如求最大值、最小值等等。它可以非常显著地降低时间复杂度,提高代码的执行效率。

动态规划能解决的问题有什么规律可循呢?
1.问题的解决可以分解为多阶段处理,且是求解最优解。多阶段决策最优解模型。
2.每个阶段互不影响。
3.问题的最优解包含子问题的最优解。
4.不同的决策序列,到达某个相同的阶段时,可能会产生重复的状态。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,294评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,780评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,001评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,593评论 1 289
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,687评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,679评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,667评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,426评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,872评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,180评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,346评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,019评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,658评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,268评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,495评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,275评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,207评论 2 352

推荐阅读更多精彩内容