当前位置: 首页 > news >正文

贪心算法.

贪心算法是指只从当前角度出发,做出当前情景下最好的选择,在某种意义上来说是局部最优解,并不从全局的角度做决策.如果贪心策略选择不恰当,可能无法得到全局最优解.

贪心算法的基本流程如下:

1.分析问题,确定优化目标,对变量进行初始化

2.制定贪心策略:在制定贪心策略时需要证明所选贪心策略一定可以得到全局最优解,若找到反例则推翻当前贪心策略,重新确定贪心策略.

完全背包问题

本节以完全背包问题为例,说明贪心算法的重要性.

给定一些物品,用matrix表示各个物品的属性,第一项表示物品的质量,第二项表示物品的总价值.现有一背包最大承重为M,试求如何装入以上物品能使背包中所装物品价值最高.

1.选取价值最大的物品,优先放入背包,举反例如下:

matrix=[(20,30),(10,40),(10,30)]

M=20

根据贪心策略,首先将价值最高的1放入背包,此时背包价值为30,但是如果将物品2和3都放入背包,总价值是70.由此可见,贪心策略并不能得到最优解

2.选取重量最小的物品优先放入背包,现举反例如下:

matrix=[(10,5),(20,10),(40,50)]

M=40

根据贪心策略,首先先将重量最小的1放入背包,再将物品2放入背包,此时重量为30,物品3已经无法放入了.此时总价值为15,而直接放入物品3的总价值为50.由此可见贪心算法得不到最优解

由上述分析可以得知,在解决一个问题时,贪心策略是多种多样的,但所制定的贪心策略并不一定是最优解,并且一个贪心策略要经得起推敲,而不是轻易就可以举出反例.

http://www.lryc.cn/news/510253.html

相关文章:

  • Linux系统和makefile详解
  • GitLab 将停止为中国区用户提供服务,60天迁移期如何应对? | LeetTalk Daily
  • 【杂谈】-AI搜索引擎如何改变传统SEO及其在内容营销中的作用
  • PTA数据结构编程题7-1最大子列和问题
  • 深入浅出:AWT的基本组件及其应用
  • MySQL45讲 第三十六讲 为什么临时表可以重名?——阅读总结
  • WebRTC服务质量(11)- Pacer机制(03) IntervalBudget
  • .NET常用的ORM框架及性能优劣分析总结
  • Ubuntu网络配置(桥接模式, nat模式, host主机模式)
  • 光通信复习
  • 数字化转型中的投资决策:IT平台投资与业务应用投资的思考
  • Linux快速入门-Linux的常用命令
  • 【ORB-SLAM3:相机针孔模型和相机K8模型】
  • Python函数(十二):函数的创建和调用、参数传递、返回值
  • 掌握Docker命令与Dockerfile实战技巧:快速构建高效容器化应用
  • Virtualbox硬盘扩容
  • 10G光纤反射内存卡
  • 信创数据防泄漏中信创沙箱是什么样的安全方案
  • 虚幻引擎结构之TArray
  • 【搭建一个网上商城系统】
  • 【gopher的java学习笔记】Spring Boot Starter初探
  • web服务器之云主机、物理机租用、服务器托管的区别
  • centos制作离线安装包
  • 论文解读——掌纹生成网络 RPG-Palm升级版PCE-Palm
  • Android修行手册 - 移动端几种常用动画方案对比
  • 16 循环语句——for循环
  • 代码随想录-笔记-其八
  • Effective C++ 条款 15:在资源管理类中提供对原始资源的访问
  • Linux高并发服务器开发 第五天(压缩解压缩/vim编辑器/查找替换/分屏操作/vim的配置)
  • C++ 面向对象编程:关系运算符重载、函数调用运算符重载