• 贪心算法一:最优装载问题



      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 }

  • 相关阅读:
    JAVAWeb Session 会话概述与基本用法
    【Kotlin】private、 protected、 internal 和 public指定修饰符的区别
    CSRF 001
    YOLO目标检测——红细胞数据集【(含对应voc、coco和yolo三种格式标签】
    SoftTriple Loss
    Git Flow 的正确使用姿势
    哈希表(哈希函数和处理哈希冲突)_20230528
    合作对策模型的简单实现
    vue3+vite3+vant搭建移动端简易模版
    LLM预训练之RLHF(一):RLHF及其变种
  • 原文地址:https://blog.csdn.net/weixin_67271870/article/details/128010769