贪心算法一:最优装载问题
admin
2024-02-23 08:28:19
0

  1.基本思想:

  贪心算法是通过一系列的选择来得到问题的解,它所做的选择都是当前情况下最优的选择,即贪心算法并不考虑整体最优,而考虑的是当前情况下的局部最优,即贪心选择。

  2.贪心算法的两个性质:

  1)贪心选择性质:所求解的问题的整体最优解可以通过一系列局部最优的选择来,即贪心选择达到。贪心选择所依赖的是以前所做过的选择,而对以后所做的选择没有关系。

  2)最优子结构性质:一个问题的最优解包含其子问题的最优解。

  3.贪心算法与动态规划的区别:

  动态规划是通过自底向上的方式解决子问题,贪心算法是通过自顶向下的迭代方式做出贪心选择,求解问题的最优解。两共同点是都具有最优子结构性质。

  4.最优装载问题:采用重量最轻者先装载的贪心选择策略。

  

 1 #include "stdafx.h"  2 #include    3 using namespace std;4 const int N = 4;5 template 6 void Swap(type &x, type &y){7     type temp = x;8     x = y;9     y = temp;
10 }
11 void BubleSort(int w[],int t[], int n){
12     for (int i = 1; i <= n; i++)
13     {
14         t[i] = i;
15     }
16 
17     for  (int i = 1;  i < n; i++)
18     {
19         int temp = i;
20         for (int j =i+1; j <= n; j++){
21             if (w[temp]>w[j])
22             {
23                 temp = j;
24                 Swap(w[i], w[j]);
25             }    
26         }
27         Swap(t[i], t[temp]);
28     }
29 }
30 void BestLoad(int w[], int x[],int c, int n){
31     
32     int t[N + 1] = {0};//记录原始索引
33     BubleSort(w, t, N);
34     for (int i = 1; i <= n; i++)
35     {
36         x[i] = 0;
37     }
38     for (int i = 1; i <= n&& w[t[i]] <= c; i++)
39     {
40         x[t[i]] = 1;
41         c -= w[t[i]];
42     }
43 }
44 int main(){
45     int c = 50;
46     int w[] = { 0, 20,10,25,15 };
47     int x[N + 1];
48     cout << "载重容量为:\n" << c << endl;
49     cout << "物品的重量分别为:" << endl;
50     for (int i = 1; i <= N; i++)
51     {
52         cout << w[i] << " ";
53     }
54     cout << endl;
55     BestLoad(w,x, c, N);
56     cout << "贪心选择结果为:" << endl;
57     for (int i = 1; i <= N; i++)
58     {
59         cout << x[i] << " ";
60     }
61     cout << endl;
62 }

相关内容

热门资讯

求日文原版的犬夜叉漫画,要日文... 求日文原版的犬夜叉漫画,要日文原版的全部56卷不用买的,你到漫漫看啊,等等漫画网站里看看都有的,犬夜...
东方四大鬼宅之首,是巫术求子还... 东方四大鬼宅之首,是巫术求子还是弑母取婴应该是后者,毕竟名称就已经看出残忍程度了。
花言巧语哄骗成语 花言巧语哄骗成语 甜言蜜语[tián yán mì yǔ][释义]像蜜糖一样甜的话。比喻为了骗人而...
下五子棋的作文 下五子棋的作文写两个人下棋,然后一个人总是赢,另一个人就不高兴了,不玩了。之后主动跟赢的那人道歉这很...
中国联通大王卡如何手动触发日租... 中国联通大王卡如何手动触发日租宝?中国联通大王卡如何 手动触发日租宝?使用非腾讯运用上网超过10m ...
把猫咪关阳台养好不好 把猫咪关阳台养好不好一般情况下,猫咪要是一直家养,而且也不放出去的话 ,应该的不会脏的,所以是用不着...
2025杭州中考复读流程详细指... 2025杭州中考复读流程详细指南 2025杭州中考复读流程详细指南 面对中考的压力,很多学生和家长会...
对你一往情深的男人,通常会发出... 对你一往情深的男人,通常会发出三个信号,你知道是什么吗?非常照顾你的心情,不想让你受任何的委屈,会把...
学神和校霸是一对竹马双方父母关... 学神和校霸是一对竹马双方父母关系极好是什么小说?和校霸是一对竹马双方父母关系极好是什么小想看同求学神...
还记得大学时那个睡在你上铺的兄... 还记得大学时那个睡在你上铺的兄弟吗,你们有什么故事?大学时候是上下床,只有舍友,没有上下铺的大兄弟。...
成功的10个要素 成功的10个要素 成功的10个要素   成功的10个要素,成功的环境只选一定要成功的人,如果你想...
谁有关于家的漫画,绘画啊!!急... 谁有关于家的漫画,绘画啊!!急求要突出家的温馨!不是现实中图片!... 要突出家的温馨!不是现实中...
国产爱情电影 国产爱情电影新旧都行~越详细越好 呵呵 谢了 越经典越好! ~国产的!男才女貌 余文乐和高圆圆主演,...
殿堂型 厅堂型 抬梁式 穿斗式... 殿堂型 厅堂型 抬梁式 穿斗式 不明白啊殿堂比厅堂高级,殿堂厅堂都有抬梁,穿斗是最低级别的
说一说长大以后要做什么简单说明... 说一说长大以后要做什么简单说明一下道理,不少于一百字?长大了当一名自由画者,去到世界各地,画出各个地...
三尸语凌降回来了吗 三尸语凌降回来了吗《三尸语》凌降回来了吗《三尸语2》凌降回来了。《三尸语》为网络作者“洛小阳”所著灵...
满地月光似海洋结局他们在一起了... 满地月光似海洋结局他们在一起了吗满地月光似海洋结局他们在一起了,这是一言情小说。
彩虹岛里各个宝箱有什么用 彩虹岛里各个宝箱有什么用可以开出各类宝物如果你人品不是超高我的建议最好不开除了蛇龙那些目前蛇龙的和椴...
什么叫民间故事 什么叫民间故事 民间故事就是劳动人民创作并传播的、具有虚构内容的散文形式的口头文学作品,是所有民...
玉兔有怎样的传说? 玉兔有怎样的传说?兔子是中秋节的又一标志。相传居于月宫的嫦娥,怀中抱有一只兔子,浑身洁白如玉,故称作...