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

  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 }

相关内容

热门资讯

复刻贵州馆子味!家常泡椒炒牛肉... 贵州泡椒炒牛肉是一道充满地方特色的家常菜,它以鲜嫩的牛肉和酸辣开胃的泡椒为主要食材,成菜香气扑鼻,口...
黔寨风味“黄金派”:外酥内糯,... 在贵州连绵的群山与缭绕的云雾间,散落着许多古老村寨。这里不仅保留着深厚的民族传统,更隐藏着无数令人惊...
大妈教你东北芥菜疙瘩的腌制方法... 眼下正是腌菜的好时节,每年这个时候,我总会想起东北大娘腌的芥菜疙瘩,那味道堪称一绝。她的做法特别简单...
原创 一... 家人们谁懂啊!黑椒牛肉配杏鲍菇真的是神仙组合!软嫩多汁的牛肉裹着浓郁的黑椒酱汁,杏鲍菇吸饱了肉香变得...