码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 贪心算法一:最优装载问题



      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 }

  • 相关阅读:
    vue直接添加属性是否响应式
    MySQL基础——DDL、DML、DQL、DCL语句
    【机器学习300问】118、循环神经网络(RNN)的基本结构是怎样的?
    【Socket】①Socket技术概述
    C语言 局部变量和全局变量
    手机号码认证什么价格?手机号码认证怎样申请?
    关于netty的一些你需要知道的内容(4)
    保健品行业正在升级,你准备好了吗?
    代码随想录算法训练营第23期day11 | 20. 有效的括号、1047. 删除字符串中的所有相邻重复项 、150. 逆波兰表达式求值
    项目中升级mysql遇到的若干问题
  • 原文地址:https://blog.csdn.net/weixin_67271870/article/details/128010769
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号