当前位置:首页 > 算法 > 正文内容

【贪心】----基本概念

亿万年的星光5年前 (2021-01-28)算法6164

一、基本概念

所谓贪心算法是指,在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以考虑,它所做出的仅仅是在某种意义上的局部最优解
贪心算法没有固定的算法框架,算法设计的关键是贪心策略的选择。必须注意的是,贪心算法不是对所有问题都能得到整体最优解,选择的贪心策略必须具备无后效性(即某个状态以后的过程不会影响以前的状态,只与当前状态有关。)

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

二、基本思路

(1)建立数学模型来描述问题

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

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

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

三、问题

(1)不能保证求得的最后解是最佳的

(2)不能用来求最大值或最小值的问题

(3)只能求满足某些约束条件的可行解的范围

四、算法框架

从问题的某一初始解出发:
while (朝给定总目标前进一步)
{
    利用可行的决策,求出可行解的一个解元素。
}
由所有解元素组合成问题的一个可行解;

五、常见例题

1.找零钱问题
2.背包类问题

  • 部分背包

  • 01背包

  • 最优装载

  • 乘船问题


3.区间类问题

  • 区间调度

  • 区间选点

  • 区间覆盖


4.排队接水问题
5.导弹拦截问题
6.过河问题


    扫描二维码推送至手机访问。

    版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

    分享给朋友:

    相关文章

    【贪心】 导弹拦截

    【贪心】 导弹拦截

    【题目描述】某国为了防御敌国的导弹袭击,开发出一种导弹拦截系统,但是这种拦截系统有一个缺陷:虽然它的第一发炮弹能够到达任意的高度,但是以后每一发炮弹都不能高于前一发的高度。某天,雷达捕捉到敌国的导弹来...

    【算法】高精度(1)

    一、  什么是高精度高精度算法,属于处理大数字的数学计算方法。在一般的科学计算中,会经常算到小数点后几百位或者更多,当然也可能是几千亿几百亿的大数字。一般这类数字我们统称为高精度数,高精度算...

    【排序】----选择排序

    【排序】----选择排序

    1.基本思想每一趟从待排序的数据元素中选出最小(或最大)的一个元素,顺序放在待排序的数列最前,直到全部待排序的数据排完。2.过程首先初始化最小元素索引值为首元素。依次遍历待排序数列,遇到小于该最小索引...

    【算法】归并排序

    【算法】归并排序

    一、基本思想归并排序的核心思想是将两个已经有序的子序列合并成一个有序序列。整个过程分为两个主要步骤: 1.分解:将待排序的序列不断二分,直到每个子序列只包含一个元素(此时自然有序) ...

    【算法】动态规划(二)——数字三角形问题

    【算法】动态规划(二)——数字三角形问题

    1.问题描述及状态定义数字三角形问题:有一个非负整数组成的三角形,第一行只有一个数,除了最下行之外每个数字的坐下方和右下方各有一个数。如下图所示:从第一行开的数开始走,每次可以往下或右走一格,直到走到...

    【贪心】区间调度

    【贪心】区间调度

    【题目描述】有n项工作,每项工作分别在si时间开始,在ti时间结束。对于每项工作,你都可以选择参与与否。如果选择了参与,那么自始至终都必须全程参与。此外,参与工作的时间段不能重叠(即使是开始与结束的瞬...