算法小专栏:贪心算法

本篇将介绍贪心算法相关知识。


一、简介

贪心算法,又称“贪婪算法”。
在对问题求解时,总是做出在当前看来是最好的选择。(局部最优解)
也就是说,不从整体最优上加以考虑,他所做出的仅是在某种意义上的局部最优解
贪心算法不是对所有问题都能得到整体最优解,但对范围相当广泛的许多问题他能产生整体最优解或者是整体最优解的近似解。(来源360百科)

注:贪心算法是一种高性能算法,复杂度低,简单易用。
贪心算法求出来的结果不一定都是最优解。对于某些问题,它能求出最优解。而还有些问题,它能求出最优解的“近似解”

二、算法思想

“大事化小,小事化了”。

  • 大事化小:一个较大的问题,通过找到与子问题的重叠,把复杂的问题划分为多个小问题;

  • 小事化了:从小问题找到决策的核心,确定一种局部最优解的策略。

  • 通过计算出局部的最优解,来推出全局的最优解或近似解。

伪代码如下:

从问题的某一初始解出发
    while (能朝给定总目标前进一步) 
        do
            选择当前最优解作为可行解的一个解元素;
    由所有解元素组合成问题的一个可行解。

三、找零问题

这是一个求得最优解的贪心算法例子。

场景:一名收银员,需要找零88元。
怎么找零,所需要的纸/硬币的数量最少。

思路:依次找最大的纸币,
例如:找零88元,¥88 = ¥50 + ¥20 + ¥10 + ¥5 + ¥1 * 3

# arr的每一位:分别对应100块、50块、20块、10块、5块、1块纸币。
arr = [0,0,0,0,0,0]

def change(money):
    while money >= 1:
        if money >= 100:
            money -= 100
            arr[0] += 1
        elif money >= 50:
            money -= 50
            arr[1] += 1
        elif money >= 20:
            money -= 20
            arr[2] += 1
        elif money >= 10:
            money -= 10
            arr[3] += 1
        elif money >= 5:
            money -= 5
            arr[4] += 1
        elif money >= 1:
            money -= 1
            arr[5] += 1

change(88)
print arr

结果输出:

四、0-1背包问题

这是一个求得最优解的近似解的贪心算法例子。
而如果要想求得最优解,就要用到DP策略。而动态规划将在下篇介绍。

场景:一个小偷去商场偷东西,在背包称重有限下,如何拿能使得获得收益越大?(每件商品只有一个,只能选择拿与不拿)

  • 贪心策略1:每次取当前能拿得下的最值钱的商品。
  • 贪心策略2:每次取当前重量最轻的商品。
  • 贪心策略3:每次取性价比最高的商品。(即价格/重量的值最大的商品)

接下来我们依次分析,并且找出不是最优解的反例。

贪心策略1:选取价值最大的商品。

反例:
背包最大重量 W = 4kg

商品 价格 重量
商品A 3000元 4kg
商品B 2000元 3kg
商品C 1500元 1kg

根据策略,首先选取商品A,接下来就无法再选取了,可是明明选取商品B、C更好。

贪心策略2:选取重量最轻的商品。

与策略1类似,举反例:
背包最大重量 W = 4kg

商品 价格 重量
商品A 3500元 4kg
商品B 2000元 3kg
商品C 1000元 1kg

根据策略,首先选取商品C,接下来选取商品B,可是明明选取A更好。

贪心策略3:选取性价比高的商品。

举反例:

背包最大重量 W = 4kg

商品 价格 重量
商品A 3500元 3.5kg
商品B 3000元 3kg
商品C 1000元 1kg

此时性价比相同,假设先选取商品A,则明明商品B、C更好。

注意:如果物品可以分割为任意大小,那么此时策略3可得最优解。否则,答案可能为近似解。

因此,关于0-1背包问题的最优解法——DP策略(动态规划)将在下章介绍。

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

推荐阅读更多精彩内容

  • 级别: ★☆☆☆☆标签:「算法」「贪心」「贪婪」作者: MrLiuQ审校: QiShare团队 本篇将介绍贪心算法...
    QiShare阅读 2,053评论 0 8
  • 一、概念 贪心算法,又称贪婪算法,是指在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以...
    TomyZhang阅读 332评论 0 0
  • 分治算法 一、基本概念 在计算机科学中,分治法是一种很重要的算法。字面上的解释是“分而治之”,就是把一个复杂的问题...
    木叶秋声阅读 5,249评论 0 3
  • 一、基本概念: 所谓贪心算法是指,在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以考虑...
    麒麟楚庄王阅读 6,894评论 0 1
  • 看这本书,就像和一位过百的老人在聊天一样,特别能找到共鸣,因为我们经历和没有经历或者正在经历的事情,她都知道。她不...
    懒癌大人动不了阅读 609评论 0 0