1.基本概念:
所谓贪心算法是指,在对问题求解时,总是做出在当前看来是最好的选择
。也就是说,
不从整体最优上加以考虑,他所做出的仅是在某种意义上的局部最优解。
贪心算法没有固定的算法框架,算法设计的关键是贪心策略的选择。必须注意的是,贪
心算法不是对所有问题都能得到整体最优解,选择的贪心策略必须具备无后效性,即某个状
态以后的过程不会影响以前的状态,只与当前状态有关。
所以对所采用的贪心策略一定要仔细分析其是否满足无后效性。
2.简要介绍:
一、基本思路
1.建立数学模型来描述问题。
2.把求解的问题分成若干个子问题。
3.对每一子问题求解,得到子问题的局部最优解。
4.把子问题的解局部最优解合成原来解问题的一个解。
二、适用问题
贪心策略适用的前提是:
局部最优策略能导致产生全局最优解
。
三、实现框架
从问题的某一初始解出发;
while (能朝给定总目标前进一步)
{
利用可行的决策,求出可行解的一个解元素;
}
由所有解元素组合成问题的一个可行解;
四、贪心策略的选择
因为用贪心算法只能通过
解局部最优解
的策略来达到全局最优解,因此,一定要注意判断
问题是否适合采用贪心算法策略,找到的解是否一定是问题的最优解。
3.例题:
最优装载问题
【问题描述】
有一日,悟空和八戒外出,发现了一棵苹果树,准备摘一些苹果回去,而他们只带了
一个袋子。该袋子能承受的重量为 C,每个苹果的重量为 w,他们
最多
能装多少个苹果呢?
输入
:第一行为袋子承重量 C 和苹果个数 n 。第二行是 n 个整数,表示 n 个苹果的重量。
输出
:最多可以装下的苹果数量。
【样例输入】
306
101568123
【样例输出】4
【策略】
要想苹果数量尽可能多,则优先选择重量小的苹果。
程序:
#include <iostream>
#include <algorithm>
using namespace std;
int w[1001], c, n;
int main() {
cin >> c >> n;
for (int i = 1; i <= n; i++) cin >> w[i];
sort(w + 1, w + 1 + n);
int temp = 0, ans = 0;
for (int i = 1; i <= n; i++){
temp += w[i];
if (temp <= c) ans++;
else break;
}
cout << ans;
return 0;
}