一、什么是贪心

贪心算法嘛、、、

就是在对某个问题求解时,总是做出在当前看来是最好的选择

In other wors,并不是从整体最优上加以考虑,而是在获得某种意义上的局部最优解

二、贪心算法的适用前提

局部的最优解能导致最后整体的最优解,即局部的最优解不受该部分以外的东西的影响

对于贪心算法,我们需要证明:整个问题的最优解一定由在贪心策略中存在的子问题的最优解得来的

实际上,能用贪心算法的问题很少,大部分看上去能用贪心算法去做的题目,其实都得不到最优解T T(这时候就需要运用动态规划了)

而看上去不能贪心的问题经过转化,反而可以运用贪心求解(额这个…)

三、贪心算法的基本思路:

(1)问题转化

(2)把求解的问题分成若干个子问题

(3)对每一子问题求解,得到子问题的局部最优解

(4)把子问题的解局部最优解合成原来解问题的一个解

↑上面那些@#%^*¥…&*#¥%@是不是太烦了。。。谁不懂”贪心”这两个字啊≥v≤~

所以在实际问题中进行分析即可!

(概括为两句话:贪心算法就是按照字面意思求局部最优;但局部最优不一定是整体最优,故需要证明成立)

四、简单贪心算法例题

BZOJ1689 [Usaco2005 Open] Muddy roads 泥泞的路

给一个长度为N的格子,一些格子有水。现在有长度为L的东西(比如,木板)覆盖,问至少要用几木板才能把水坑都盖住。

解法是:每个木板在当前满足条件的情况下尽量往后放。

证明:假设当前i有水,i-1没有水,因为长度是固定的,那么显然从i放,由于从i-1放木板有可能会少盖住一个后面的水池。

于是模拟怎么放木板即可。

另两题:

BZOJ2014 [Usaco2010 Feb]Chocolate Buying

BZOJ3544 [ONTAK2010]Creative Accounting

五、进阶版贪心算法例题

BZOJ1658 [Usaco2006 Mar]Water Slides 滑水

一维坐标轴上有n个点,有些点之间有单向滑梯,现在要滑完所有滑梯仅一次,问走的路最少的解法。(n = 10000)

一开始建立的是网络流模型:

(1)把点分成出度>入度和入度>出度两种

(2)跑一遍网络流

然后会发现由于n很大,会TLE,于是进行改进:

发现两条滑梯交叉滑一定没有不交叉滑来得好(就是简单地贪心思想)

于是对两类点排序,直接一个一个配对答案一定是最小的。

另一题:

BZOJ1367 [Baltic2004]sequence

六、贪心的更多例题

BZOJ1046 [HAOI2007]上升序列

BZOJ1691 [Usaco2007 Dec]挑剔的美食家

BZOJ1150 [CTSC2007]数据备份Backup

七、More about贪心

贪心作为一类重要的信息学算法,一般并不是单独使用的

有时会利用堆来优化,也可能配合hash甚至平衡树进行问题的求解

当然也可以作为一个算法的一部分(如Dijkstra),或者”部分贪心思”

当然这种看似简单、其实内容丰富的算法就可以被出在NOIp中。。。。。。

noip知识点总结之--贪心的更多相关文章

  1. Noip知识点备考

    作为一个oier,适当的整理是有必要的.蒟蒻根据自己的理解,筛选出考noip应当掌握的知识点.可能后期还有解题思路和模板,先挖个坑慢慢补呗. 60级张炳琪Noip知识点总结 可能是本人比较弱,写的内容 ...

  2. NOIp知识点复习——最短路计数

    $Mingqi\_H$ NOIp 2017考挂了...gg 重新开始好了. 计划明年2月24号前复习完所有的NOIp知识点(毕竟很不熟练啊),之后到七月底前学习完省选的东西(flag?). 从现在开始 ...

  3. noip知识点总结之--欧几里得算法和扩展欧几里得算法

    一.欧几里得算法 名字非常高大上的不一定难,比如欧几里得算法...其实就是求两个正整数a, b的最大公约数(即gcd),亦称辗转相除法 需要先知道一个定理: gcd(a, b) = gcd(b, a  ...

  4. noip推荐系列:汽艇[贪心]

    [问题背景] 一天sxc,zsx,wl到gly坐汽艇,本来和其他的人约好了一起去,结果被放了鸽子,3人便只有一人负担x元去坐汽艇(很贵哦).坐了才发现如果汽艇上人多了位置就不宽敞,就不好玩了.而3个人 ...

  5. NOIP知识点

    基础算法 贪心 枚举 分治 二分 倍增 高精度 模拟 图论 图 最短路(dijkstra.spfa.floyd) 最小生成树(kruskal.prim) 并查集 拓扑排序 二分图染色 Tarjan 树 ...

  6. NOI&&NOIP知识点集萃

    更新日志 \(update:2019-3-4\) 更新了自为风月马前卒的后缀数组(省选不到一个月了,我才开始学后缀数组怕是要凉凉) \(update:2019-2-21\) 更新了一篇李超线段树的讲解 ...

  7. 2018.09.08 NOIP模拟eat(贪心)

    签到水题啊... 这题完全跟图论没有关系. 显然如果确定了哪些点会被选之后顺序已经不重要了.于是我们给点按权值排序贪心从大向小选. 我们要求的显然就是∑i(a[i]−(n−i))" role ...

  8. 2018.08.18 NOIP模拟 travel(贪心)

    Travel 题目背景 SOURCE:NOIP2015-SHY4 题目描述 小 A 要进行一次旅行.这回他要在序号为 1 到 n 的 n 个城市之间旅行.这 n 个城市之间共有 m 条连接两个城市的单 ...

  9. NOIp 2018 货币系统 贪心

    题目描述 在网友的国度中共有 nnn 种不同面额的货币,第 iii 种货币的面额为 a[i]a[i]a[i],你可以假设每一种货币都有无穷多张.为了方便,我们把货币种数为 nnn.面额数组为 a[1. ...

随机推荐

  1. luabind 导出string问题

    luabind导出字符串 不能导出char* 会有问题 应该是字符串连接的时候出错了 static _TCHAR* pRetChar = new _TCHAR[10]; memcpy(pRetChar ...

  2. iOS - UISwitch

    前言 NS_CLASS_AVAILABLE_IOS(2_0) __TVOS_PROHIBITED @interface UISwitch : UIControl <NSCoding> @a ...

  3. fFFmpeg 命令、案例、测试集中营

    gitbook: https://www.gitbook.com/book/xdsnet/other-doc-cn-ffmpeg/details ffmpeg [全局选项] {[输入文件选项] -i ...

  4. java获取中问名字的首字母

    public class FirstLetterUtil { private static int BEGIN = 45217; private static int END = 63486; // ...

  5. mysql 聚集函数需要注意的问题

    1.当没有记录的时候,使用聚集函数,会导致出现一条记录,记录的取值都是NULL,如下:mysql> select name from student where name='David';Emp ...

  6. (六)ARM状态寄存器-PSR

    ARM程序状态寄存器Program State Register 在ARM模式中, 有16个数据寄存器和1或2个状态寄存器是可以随时访问的.在特权模式 (privileged mode) 下, 对应的 ...

  7. html的空格和换行显示【摘自网络】

    一.HTML 代码中的所有连续的空格或空行(换行)都会被显示为一个空格,不管是内容还是标签之间. 二.当我们想让它们在同一行连续显示时,就让所有的代码之间没有空格,也不要换行. 三.当我们想要显示连续 ...

  8. 怎样使用ServletContextListener接口

    ServletContext : 每一个web应用都有一个 ServletContext与之相关联. ServletContext对象在应用启动的被创建,在应用关闭的时候被销毁. ServletCon ...

  9. Django缓存优化之redis

    Redis 概述 Redis 是一个开源的Inmemory key-value 存储系统,性能高,很大程度上补偿了 memcached 的不足.支持多种存储类型,包括 string, list, se ...

  10. Weka 3: Data Mining Software in Java

    官方网站: Weka 3: Data Mining Software in Java 相关使用方法博客 WEKA使用教程(经典教程转载) (实例数据:bank-data.csv) Weka初步一.二. ...