博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
贪心算法之最优装载
阅读量:6677 次
发布时间:2019-06-25

本文共 1026 字,大约阅读时间需要 3 分钟。

贪心算法通过一系列的选择来得到问题的解。它所做的每一个选择都是当前状态下局部最好选择。从许多的贪心算法求解的问题可以看到可用贪心算法求解的问题一般具有两个重要的性质:贪心选择性质和最优子结构性质。

1、贪心选择性质

贪心选择性质是 指所求问题的整体最优解可以通过一系列局部最优的选择,即贪心选择来达到。与动态规划算法的不同之处是贪心算法只依赖在当前状态下做出最优选择,然后再去解做出这个选择后产生的相应的子问题。贪心算法依赖于以往做出的选择,但是绝不依赖未来做出的选择。所以贪心算法是自顶向下解决问题的。

2、最优子结构性质

当一个问题的最优解包含其子问题的最优解时,称此问题具有最优子结构性质。一个问题是否具有最优子结构性质是该问题可用动态规划算法或贪心算法求解的关键特征。

下面是贪算法的最简单的一个实例,最优装载问题:

问题描述:

有一批集装箱要装上一艘载重量为c的货船。其中集装箱i的重量为n[i],问在不受体积限制的情况下,将尽可能多的集装箱装上船?

贪心算法之最优装载算法:

1、选择重量小的先装,所以首先需要排序。
2、不断装载,则是循环,要输出最优装载方案,则是需要进行记录装载
到的位置的。使用loading记录现在的装载量

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
void 
Load(
int 
data[],
int 
n,
int 
c)      
//最优装载函数
{
    
int 
pos=0,i=0;
    
int 
loading=0;
    
InsertSort(data,n);
//排序
    
while
(loading<c&&i<n)
//如果总和还是小于c,i就有可能持续增大越界,这里需要加上条件限制
    
{
        
loading+=data[i];
        
i++;
    
}
    
pos=--i;       
//循环内部i在loading不满足小于c时还加了1,这里减掉
 
    
cout<<
"最优装载方案为:"
<<endl;
    
for
(
int 
j=0;j<=pos;j++)
        
cout<<
":"
<<data[j]<<
"-->"
<<endl;
    
cout<<
"最多可以装载的集装箱数:"
<<pos<<endl;
 
 
}

 该问题的时间复杂度取决于排序函数的时间复杂度,这里采用的直接插入排序,所以时间复杂度为O(n^2)

转载于:https://www.cnblogs.com/ITXIAZAI/p/4115820.html

你可能感兴趣的文章
socket.io+redis+nodejs+nginx集群部署
查看>>
Angular 4.x EventManager & Custom EventManagerPlugin
查看>>
TP后台权限管理笔记
查看>>
客户端通过SSH private key 登录远端服务器
查看>>
ASP.NET SignalR增加Azure支持
查看>>
Micronaut教程:如何使用基于JVM的框架构建微服务
查看>>
利用Apache Spark SQL和DataFrames扩展关系数据库
查看>>
立下“去O”Flag的AWS,悄悄修炼了哪些内功?
查看>>
Mango 的组织重构
查看>>
Spring Boot 2.2首个里程碑版本发布,改进性能和内存使用
查看>>
James Grenning访谈录:关于测试驱动开发及代码异味
查看>>
最重要的就是做正确的事
查看>>
SUM
查看>>
旷视砸20亿进军AIoT,发布国内首个机器人协作大脑河图
查看>>
持续交付模型中文化转型的重要意义
查看>>
IE安全系列:IE浏览器的技术变迁(上)
查看>>
Facebook引入Haskell升级Sigma防御系统
查看>>
做混沌工程是什么样的体验?阿里:有点刺激
查看>>
全面布局“边” “端”,腾讯云边缘计算技术探索及落地应用
查看>>
理解Monad,一份monad的解惑指南
查看>>