第6章 贪心算法资料.

合集下载

C语言的贪心算法

C语言的贪心算法

C语言的贪心算法贪心算法是一种在每一步选择中都采取当前状态下最优的选择,从而希望能够获得全局最优解的算法策略。

C语言中实现贪心算法相对简单,下面将详细介绍贪心算法的基本思想、应用场景以及一些常见问题。

一、贪心算法的基本思想贪心算法的基本思想是每一步选择中都采取当前状态下最优的选择,也就是局部最优解。

它的核心思想是:当面临一个问题时,选择当前最优解作为解决方案,并希望通过这种局部最优解的选择,最终能够获得全局最优解。

贪心算法的基本过程如下:1.建立数学模型来描述问题。

2.将问题分解为若干子问题。

3.选取当前最优解作为局部最优解,并保存,计算得出最优解。

4.利用局部最优解重新构建问题,然后继续迭代进行求解。

5.终止条件:达到最优解,或者不能再分解为子问题,或者满足特定条件。

二、贪心算法的应用场景贪心算法在很多问题的解决中都具有广泛的应用,但它并不是万能的,只适用于满足贪心选择性质的问题。

常见的应用场景包括:1. 最小生成树:如Prim算法和Kruskal算法。

2. 最短路径问题:如Dijkstra算法。

3.活动安排问题:如区间调度问题。

4.霍夫曼编码:用于数据压缩。

5.背包问题:如0-1背包问题和部分分数背包问题。

6.跳跃游戏:在一定规则下,从起点跳到终点,每一步跳跃的最大距离为当前位置上的数值,并判断是否能跳到终点。

三、贪心算法的示例问题1.区间调度问题假设有n个区间,每个区间都有一个开始时间和结束时间,现在需要选出不重叠的区间个数最多的子集。

贪心选择策略是:优先选择结束时间早的区间,然后从剩余区间中再次选择结束时间早的区间。

可以按照以下步骤实现:a.对区间按照结束时间进行升序排序。

b.选择第一个区间,结束时间最早。

c.从剩余区间中选择结束时间与前一个区间开始时间不重叠的区间。

d.重复步骤c,直到无法再选出满足条件的区间为止。

2.霍夫曼编码问题给定一个字母集合和其对应的概率,现需要将字母集合进行编码,使得总编码长度最短。

贪心算法的基本原理

贪心算法的基本原理

贪心算法的基本原理贪心算法(Greedy Algorithm)是一种常用的算法思想,它在求解最优化问题时通常能够得到较好的近似解。

贪心算法的基本原理是:每一步都选择当前状态下的最优解,从而希望最终能够得到全局最优解。

在实际应用中,贪心算法常常用于解决一些最优化问题,如最小生成树、最短路径、任务调度等。

一、贪心算法的特点贪心算法具有以下特点:1. 简单:贪心算法通常比较简单,易于实现和理解。

2. 高效:贪心算法的时间复杂度通常较低,能够在较短的时间内得到结果。

3. 局部最优:每一步都选择当前状态下的最优解,但不能保证最终能够得到全局最优解。

4. 适用范围:贪心算法适用于一些特定类型的问题,如无后效性、最优子结构等。

二、贪心算法的基本原理贪心算法的基本原理可以概括为以下几个步骤:1. 初始状态:确定问题的初始状态,定义问题的输入和输出。

2. 状态转移:根据当前状态,选择局部最优解,并更新状态。

3. 筛选解:判断当前状态下是否满足问题的约束条件,若满足则保留该解,否则舍弃。

4. 终止条件:重复以上步骤,直至满足终止条件,得到最终解。

三、贪心算法的应用举例1. 找零钱:假设有 25、10、5、1 四种面额的硬币,需要找零 41 元,如何使得找零的硬币数量最少?贪心算法可以先选择面额最大的硬币,然后逐步选择面额较小的硬币,直至找零完毕。

2. 区间调度:给定一组区间,如何选择最多的互不重叠的区间?贪心算法可以先按照区间的结束时间排序,然后依次选择结束时间最早的区间,直至所有区间都被覆盖。

3. 最小生成树:在一个连通的带权无向图中,如何选择边使得生成树的权值最小?贪心算法可以按照边的权值从小到大排序,然后依次选择权值最小且不构成环的边,直至所有顶点都被连接。

四、贪心算法的优缺点1. 优点:贪心算法简单高效,适用于一些特定类型的问题,能够在较短的时间内得到近似最优解。

2. 缺点:贪心算法不能保证一定能够得到全局最优解,可能会出现局部最优解不是全局最优解的情况。

贪心算法程序设计

贪心算法程序设计

贪心算法程序设计贪心算法程序设计1. 什么是贪心算法贪心算法(Greedy Algorithm)是一种常见的算法思想,它在每一步选择中都采取当前状态下的最优选择,从而希望最终达到全局最优解。

贪心算法的核心思想是局部最优解能导致全局最优解。

2. 贪心算法的基本步骤贪心算法的基本步骤如下:1. 定义问题的优化目标。

2. 将问题分解成子问题。

3. 选择当前最优的子问题解,将子问题的解合并成原问题的解。

4. 检查是否达到了问题的优化目标,如果没有达到,则回到第二步,继续寻找下一个最优子问题解。

5. 在所有子问题解合并成原问题解后,得到问题的最优解。

3. 贪心算法的应用场景贪心算法的应用非常广泛,几乎可以用于解决各种优化问题。

以下几个常见的应用场景:1. 零钱找零问题:给定一定面额的纸币和硬币,如何找零使得所需纸币和硬币的数量最小?2. 区间调度问题:给定一些活动的开始时间和结束时间,如何安排活动使得可以办理的活动数量最大?3. 背包问题:给定一些具有重量和价值的物品,如何选择物品使得背包的总价值最大?4. 最小树问题:给定一个带权无向图,如何找到一棵树,使得它的边权之和最小?5. 哈夫曼编码问题:给定一组字符和相应的频率,如何构造一个满足最低编码长度限制的二进制编码?4. 贪心算法的优缺点贪心算法的优点是简单、高效,可以快速得到一个近似最优解。

而且对于一些问题,贪心算法能够得到全局最优解。

贪心算法的缺点在于它不一定能够得到全局最优解,因为在每一步只考虑局部最优解,无法回溯到之前的选择。

5. 贪心算法的程序设计在使用贪心算法进行程序设计时,通常需要以下几个步骤:1. 定义问题的优化目标。

2. 将问题分解成子问题,并设计子问题的解决方案。

3. 设计贪心选择策略,选择局部最优解。

4. 设计贪心算法的递推或迭代公式。

5. 判断贪心算法是否能够得到全局最优解。

6. 编写程序实现贪心算法。

6.贪心算法是一种常见的算法思想,它在每一步选择中都采取当前状态下的最优选择,从而希望最终达到全局最优解。

贪心算法的常用范围

贪心算法的常用范围

贪心算法的常用范围一、什么是贪心算法?听我说,贪心算法其实就像你身边那些总是想着“现在最好的”那一类人。

啥意思呢?就是他们做事从来不考虑长远,只看眼前能捞多少,想法很简单,行动也特别直接。

比如说你去吃自助餐,眼前有一盘热腾腾的牛排,你只顾着夹那块,脑袋里想的就是“现在不吃,等下没了怎么办”。

这就有点像贪心算法,它在每一步选择中都追求局部的最优解。

问题是,这种做法能得出全局最优解吗?不一定哦。

所以,贪心算法适用的地方就有点挑剔,它只适合那些能通过局部最优解来推导出全局最优解的情况。

二、贪心算法的常见应用1. 活动安排问题咱们先来说个生活中常见的例子,活动安排问题。

假设你是一个忙碌的白领,今天有好多活动要参加,可惜你一整天的时间有限。

怎么安排才能把活动都参加个遍呢?如果你是那种贪心心态的家伙,你会选择哪个活动呢?肯定是选那些花费时间最少,能带来最大回报的活动嘛!简单粗暴的办法就像贪心算法一样,选择每一个最短时间的活动,把空余的时间都填满。

最终,你可能会发现,虽然你参加了很多活动,但并不一定能让你得到最大的收益。

所以说,这个问题就是一个典型的贪心算法的使用场景。

2. 找零问题还有个经典的例子是找零问题。

你去商店买东西,店员找给你零钱。

那如果你是商店的老板,应该怎么挑零钱呢?你肯定会选择把金额大的零钱先找给顾客吧,简单快捷又高效。

比如,顾客给你100块钱,你就找个50块、20块,再来几张5块,剩下的用1块来凑,最后一结账,顾客就满意地走了。

这个过程中,你是按照每次找最大的零钱进行选择,这就是贪心算法的一个典型应用。

找零问题背后就是一个在每一步都做出“局部最优选择”的过程,能够确保找到的零钱数量最少,操作也最为高效。

3. 最短路径问题再说个计算机里的例子,最短路径问题。

在一个图中,假如你是要从A点出发去B 点,你要怎么走才能最省力、最省时?这里的贪心算法会告诉你:每次从当前位置出发,选择一个最短的路径走,这样一步一步走下去,最后就能到达B点了。

贪心算法(陈鹏)

贪心算法(陈鹏)

— 20 —
江苏省青少年信息学奥林匹克竞赛委员会 | 版权所有
© Copyright JSOI 2010
JSOI2010江苏省青少年信息学奥林匹克集训队(夏令营)
2、贪心算法的特点
[贪心算法解题的一般步骤] 1、设计数据找规律 2、进行贪心猜想 3、正确性证明(严格证明和一般证明) ·严格证明:数学归纳和反证法 ·一般证明:列举反例 4、程序实现
— 12 —
江苏省青少年信息学奥林匹克竞赛委员会 | 版权所有
© Copyright JSOI 2010
JSOI201——纪念品分组(NOIP2007普及组)
[输入输出样例] 输入: 输出: 100 6 9 90 20 20 30 50 60 70 80 90
若无法证明, 此步骤可缺省
— 21 —
江苏省青少年信息学奥林匹克竞赛委员会 | 版权所有
© Copyright JSOI 2010
JSOI2010江苏省青少年信息学奥林匹克集训队(夏令营)
2、贪心算法的特点
[典型的贪心算法简介] 贪心策略在树和图论中有着极其重要的应用,Prim、 Kruskal、Huffman等体现“贪心”思想的算法更是广泛地 应用于树与图的处理。 下面介绍一种利用“贪心”思想的算法——哈夫曼 (Huffman)树。
—7—
江苏省青少年信息学奥林匹克竞赛委员会 | 版权所有
© Copyright JSOI 2010
JSOI2010江苏省青少年信息学奥林匹克集训队(夏令营)
1、贪心概念
[求解这类问题的方法] 1、搜索 最原始的方法是搜索(穷举)法。当然,为了尽快搜 索出解,我们往往会利用限制条件进行可行性判断剪枝, 或利用目标函数的上界(或下界)进行分枝定界。 2、动态规划 第二种解决此类问题的方法是动态规划。当然,使用 动态规划必须要满足一些条件,如无后效性和最优子结构 等等。

贪心算法知识点总结

贪心算法知识点总结

贪心算法知识点总结1. 基本原理贪心算法的基本原理是每一步都选择当前状态下的最优解,以期望最终得到全局最优解。

具体来说,贪心算法通常可以分为以下几个步骤:1)从问题的某个初始解出发2)采用一种迭代的方式,逐步将初始解进行优化3)每一步都是基于当前状态的最优选择来进行优化4)直到无法再进行优化,得到问题的最优解由于贪心算法每一步都要选择局部最优解,因此贪心算法通常具有高效性。

然而,贪心算法并不适用于所有问题,其结果不一定是全局最优解。

因此,在使用贪心算法时需要注意问题的特性和约束条件,以免得到错误的结果。

2. 适用情况贪心算法通常适用于满足以下条件的问题:1)问题的最优解满足“最优子结构”性质:即问题的最优解包含了其子问题的最优解2)问题的求解过程具有“贪心选择性”:即每一步都选择当前状态下的最优解,并不需要考虑未来的后果3)问题的约束条件可以通过局部最优选择满足全局最优解:即问题的解空间中存在一些局部最优解,可以通过一系列的局部最优解构建全局最优解在实际应用中,贪心算法通常用于求解最优化问题,如最小生成树、最短路径、任务调度等问题。

由于贪心算法的高效性,它通常能够在较短的时间内得到较为接近最优解的结果。

然而,贪心算法并不适用于所有问题,对于一些问题,贪心算法将得到错误的结果。

因此,在使用贪心算法时需要谨慎选择问题类型和约束条件,以避免错误的结果。

3. 贪心算法实例在下面的部分,我们将介绍一些常见的贪心算法实例,包括背包问题、活动安排问题、霍夫曼编码等。

3.1 背包问题背包问题是一个经典的优化问题,它包括0-1背包问题、分数背包问题等多种类型。

在0-1背包问题中,给定n种物品和一个容量为C的背包,每种物品i的重量为w[i],价值为v[i],求在不超过背包容量的情况下,如何选择物品放入背包,可以使得背包中的总价值最大。

对于0-1背包问题,贪心算法通常不能得到最优解。

然而,在分数背包问题中,贪心算法通常可以得到近似的最优解。

C++算法-6.贪心算法

C++算法-6.贪心算法

例如:n=175438 s=4 删数的过程如下: n=175438 //删掉7 15438 //删掉5 1438 //删掉4 138 //删掉8 13 //解为13 这样,删数问题就与如何寻找递减区间首字符这样一个简单的问题对应起来。 不过还要注意一个细节性的问题,就是可能会出现字符串串首有若干0的情况, 甚至整个字符串都是0的情况。按以上贪心策略编制的程序框架如下 输入n,s; for (i=1;i<=s;++i) { //一共要删除s个字符 for ( j=0;j<len-1;++j ) //从串首开始找,len是n的长度 if ( n[j]>n[j+1] ) { //找到第一个符合条件的 for ( k=j;k<len-1;++k ) //删除字符串n的第j个字符 ,后面字符往前整 n[k]=n[k+1]; break; } --len; //长度减1 } 输出n; //删去串首可能产生的无用零
下面来看看0-1背包问题。 给定一个最大载重量为M的卡车和N种动物。已知第i种动物的重量为Wi, 其最大价值为Vi,设定M,Wi,Vi均为整数,编程确定一个装货方案,使得装 入卡车中的所有动物总价值最大。 【分析】对于n种动物,要么被装,要么不装,也就是说在满足卡车载重的 条件下,如何选择动物,使得动物价值最大的问题。 即确定一组x1,x2,…,xn, xi∈{0,1} f(x)=max(∑xi*vi) 其中,∑(xi*wi)≦w 从直观上来看,我们可以按照上例一样选择那些价值大,而重量轻的动物。 也就是可以按价值质量比(vi/wi)的大小来进行选择。可以看出,每做一次选 择,都是从剩下的动物中选择那些vi/wi最大的,这种局部最优的选择是否能满 足全局最优呢?我们来看看一个简单的例子: 设n=3,卡车最大载重量是100,三种动物a、b、c的重量分别是40,50, 70,其对应的总价值分别是80、100、150。 情况a:按照上述思路,三种动物的vi/wi分别为2,2,2.14。显然,我们首先 选择动物c,得到价值150,然后任意选择a或b,由于卡车最大载重为100,因 此卡车不能装载其他动物。 情况b:不按上述约束条件,直接选择a和b。可以得到价值80+100=180, 卡车装载的重量为40+50=90。没有超过卡车的实际载重,因此也是一种可行 解,显然,这种解比上一种解要优化。

贪 心 算 法

贪 心 算 法

贪心算法及几个常用的例题贪心算法:一、基本概念:所谓贪心算法是指,在对问题求解时,总是做出在当前看来是最好的选择。

也就是说,不从整体最优上加以考虑,他所做出的仅是在某种意义上的局部最优解。

贪心算法没有固定的算法框架,算法设计的关键是贪心策略的选择。

必须注意的是,贪心算法不是对所有问题都能得到整体最优解,选择的贪心策略必须具备无后效性,即某个状态以后的过程不会影响以前的状态,只与当前状态有关。

所以对所采用的贪心策略一定要仔细分析其是否满足无后效性。

二、贪心算法的基本思路:1.建立数学模型来描述问题。

2.把求解的问题分成若干个子问题。

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

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

三、贪心算法适用的问题贪心策略适用的前提是:局部最优策略能导致产生全局最优解。

实际上,贪心算法适用的情况很少。

一般,对一个问题分析是否适用于贪心算法,可以先选择该问题下的几个实际数据进行分析,就可做出判断。

四、贪心算法的实现框架从问题的某一初始解出发;while (能朝给定总目标前进一步)利用可行的决策,求出可行解的一个解元素;由所有解元素组合成问题的一个可行解;五、贪心策略的选择因为用贪心算法只能通过解局部最优解的策略来达到全局最优解,因此,一定要注意判断问题是否适合采用贪心算法策略,找到的解是否一定是问题的最优解。

几个经典的例子:一、定义什么是贪心算法呢?所谓贪心算法是指,在对问题求解时,总是做出在当前看来最好的选择。

也就是说,不从整体最优解出发来考虑,它所做出的仅是在某种意义上的局部最优解。

贪心算法不是对所有问题都能得到整体最优解,但对范围相当广泛的许多问题都能产生整体最优解或整体最优解的近似解。

贪心算法的基本思路如下:1. .建立数学模型来描述问题。

2. 把求解的问题分成若干个子问题。

3. 对每个子问题求解,得到每个子问题的局部最优解。

4. 把每个子问题的局部最优解合成为原来问题的一个解。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

【例2】部分背包问题
给定一个最大载重量为M的卡车和N种食品,有食盐,白糖,大米等。已知
第i种食品的最多拥有Wi公斤,其商品价值为Vi元/公斤,编程确定一个装货方案,
使得装入卡车中的所有物品总价值最大。
【算法分析】
因为每一个物品都可以分割成单位块,单位块的利益越大显然总收益越大,所以它
局部最优满足全局最优,可以用贪心法解答,方法如下:先将单位块收益按从大到小进
向给定的目标递推。但不同的是,推进的每一步不是依据某一固定的递推式,而是做
一个局部的最优选择,即贪心选择(在例中,这种贪心选择表现为选择一行中的最大
整数),这样,不断的将问题归纳为若干相似的子问题,最终产生出一个全局最优解。
特别注意的是,局部贪心的选择是否可以得出全局最优是能否采用贪心法的关键
所在。对于能否使用贪心策略,应从理论上予以证明。下面我们看看另一个问题。
下面来看看0-1背包问题。 给定一个最大载重量为M的卡车和N种动物。已知第i种动物的重量为Wi,
其最大价值为Vi,设定M,Wi,Vi均为整数,编程确定一个装货方案,使得装 入卡车中的所有动物总价值最大。
【分析】对于n种动物,要么被装,要么不装,也就是说在满足卡车载重的 条件下,如何选择动物,使得动物价值最大的问题。
cin>>n>>r; memset(s,0,sizeof(s));
//初始化
j=0; minx=0; for (i=1;i<=n;++i)
//用贪心法求解
{
j++; if (j==r+1) j=1; s[j]+=a[i];
//前r个人为一组,第r+1个人回到第一个水龙 //加上等待时间
设n=3,卡车最大载重量是100,三种动物a、b、c的重量分别是40,50, 70,其对应的总价值分别是80、100、150。
情况a:按照上述思路,三种动物的vi/wi分别为2,2,2.14。显然,我们首先 选择动物c,得到价值150,然后任意选择a或b,由于卡车最大载重为100,因 此卡车不能装载其他动物。
行排列,然后用循环从单位块收益最大的取起,直到不能取为止便得到了最优解。
因此我们非常容易设计出如下算法:
问题初始化;
//读入数据
按Vi从大到小将商品排序;来自i=1;do{
if (m==0) break;
//如果卡车满载则跳出循环
m=m-w[i];
if (m>=0)
//将第i种商品全部装入卡车
else 将(m+w[i]) 重量的物品i装入卡车;
i=i+1;
//选择下一种商品
}while (m>0&&i<=n);
在解决上述问题的过程中,首先根据题设条件,找到了贪心选择标准(Vi),
并依据这个标准直接逐步去求最优解,这种解题策略被称为贪心法。
因此,利用贪心策略解题,需要解决两个问题: 首先,确定问题是否能用贪心策略求解;一般来说,适用于贪心策略 求解的问题具有以下特点: ①可通过局部的贪心选择来达到问题的全局最优解。运用贪心策略解 题,一般来说需要一步步的进行多次的贪心选择。在经过一次贪心选择之 后,原问题将变成一个相似的,但规模更小的问题,而后的每一步都是当 前看似最佳的选择,且每一个选择都仅做一次。 ②原问题的最优解包含子问题的最优解,即问题具有最优子结构的性 质。在背包问题中,第一次选择单位重量价值最大的货物,它是第一个子 问题的最优解,第二次选择剩下的货物中单位重量价值最大的货物,同样 是第二个子问题的最优解,依次类推。 ③其次,如何选择一个贪心标准?正确的贪心标准可以得到问题的最 优解,在确定采用贪心策略解决问题时,不能随意的判断贪心标准是否正 确,尤其不要被表面上看似正确的贪心标准所迷惑。在得出贪心标准之后 应给予严格的数学证明。
(可以用数学方法简单证明,这里就不再赘述),所以这道题可以用贪心法解答,基本步
骤:
(1)将输入的时间按从小到大排序;
(2)将排序后的时间按顺序依次放入每个水龙头的队列中;
(3)统计,输出答案。
【样例输入】
【样例输出】
42
//4人打水,2个水龙头
23
2645
//每个打水时间
参考程序主要框架如下:
//总共花费时间
即确定一组x1,x2,…,xn, xi∈{0,1} f(x)=max(∑xi*vi) 其中,∑(xi*wi)≦w
从直观上来看,我们可以按照上例一样选择那些价值大,而重量轻的动物。 也就是可以按价值质量比(vi/wi)的大小来进行选择。可以看出,每做一次选 择,都是从剩下的动物中选择那些vi/wi最大的,这种局部最优的选择是否能满 足全局最优呢?我们来看看一个简单的例子:
第六章 贪心算法
若在求解一个问题时,能根据每次所得到的局部最优解,推导出全局最
优或最优目标。那么,我们可以根据这个策略,每次得到局部最优解答,逐
步而推导出问题,这种策略称为贪心法。下面我们看一些简单例题。
【例1】在N行M列的正整数矩阵中,要求从每行中选出1个数,使得选出的总共N个
数的和最大。
【算法分析】
要使总和最大,则每个数要尽可能大,自然应该选每行中最大的那个数。因此,
我们设计出如下算法:
读入N, M,矩阵数据;
Total = 0;
for (int I = 1; I <= N; ++ l)
{
//对N行进行选择
选择第I行最大的数,记为K;
Total += K;
}
输出最大总和Total;
从上例中我们可以看出,和递推法相仿,贪心法也是从问题的某一个初始解出发,
情况b:不按上述约束条件,直接选择a和b。可以得到价值80+100=180, 卡车装载的重量为40+50=90。没有超过卡车的实际载重,因此也是一种可行 解,显然,这种解比上一种解要优化。
问题出现在什么地方呢?我们看看图23
从图23中明显可以看出,情况a,卡车的空载率比情况b高。也就是说,上 面的分析,只考虑了货物的价值质量比,而没有考虑到卡车的运营效率,因此, 局部的最优化,不能导致全局的最优化。
因此,贪心不能简单进行,而需要全面的考虑,最后得到证明。
【例3】排队打水问题
有N个人排队到R个水龙头去打水,他们装满水桶的时间为T1,T2,…,Tn为整数且 各不相等,应如何安排他们的打水顺序才能使他们花费的时间最少?
【算法分析】
由于排队时,越靠前面的计算的次数越多,显然越小的排在越前面得出的结果越小
相关文档
最新文档