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

秒懂算法 | 子集树模型——0-1背包问题的回溯算法及动态规划改进

 给定n种物品和一背包。物品i的重量是wi,其价值为vi,背包的容量为W。一种物品要么全部装入背包,要么全部不装入背包,不允许部分装入。装入背包的物品的总重量不超过背包的容量。问应如何选择装入背包的物品,使得装入背包中的物品总价值最大?

01、问题分析——解空间及搜索条件

根据问题描述可知,0-1背包问题要求找出n种物品集合{1,2,…,n}中的一部分物品,将这部分物品装入背包。装进去的物品总重量不超过背包的容量且价值之和最大,即找到n种物品集合{1,2,…,n}的一个子集,这个子集中的物品总重量不超过背包的容量,且总价值是集合{1,2,…,n}的所有不超过背包容量的子集中物品总价值最大的。

按照回溯法的算法框架,首先需要定义问题的解空间,然后确定解空间的组织结构,最后进行搜索。搜索前要解决两个关键问题,一是确定问题是否需要约束条件(用于判断是否有可能产生可行解),如果需要,那么应如何设置?二是确定问题是否需要限界条件(用于判断是否有可能产生最优解),如果需要,那么应如何设置?

1定义问题的解空间

0-1背包问题是要将物品装入背包,并且物品有且只有两种状态。第i(i=1,2,…,n)种物品是装入背包能够达到目标要求,还是不装入背包能够达到目标要求呢?很显然,目前还不确定。因此,可以用变量xi表示第i种物品是否被装入背包的行为,如果用“0”表示不被

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

相关文章:

  • koc转化效果评估模型是什么?如何根据模型来进行投放
  • vuejs-datepicker|简单易用的Vue.js日期选择组件
  • 【c++】类和对象3—初始化列表、类对象作为类成员、静态成员
  • 【基础算法】数的范围
  • FreeRTOS入门(01):基础说明与使用演示
  • 华为OD机试真题Python实现【交换字符】真题+解题思路+代码(20222023)
  • Word处理控件Aspose.Words功能演示:使用 Java 在 MS Word 文档中进行邮件合并
  • 产品未出 百度朋友圈“开演”
  • emacs 中的键盘宏
  • TCP/IP网络编程——关于 I/O 流分离的其他内容
  • 【BCT认证_组播DNS】 DNS SRV RR
  • 【验证码的识别】—— 点触式验证码的识别
  • 深入浅出C++ ——priority_queue类深度剖析
  • 117.Android 简单的拖拽列表+防止越界拖动(BaseRecyclerViewAdapterHelper)
  • 什么是Struts2?有哪些优势
  • Ubuntu22.04 安装Mongodb6.X
  • 启动内核,能启动内核但是无法进入内核,始终卡在某一地方,比如 No soundcards found.
  • SQL零基础入门学习(六)
  • 股票、指数、快照、逐笔... 不同行情数据源的实时关联分析应用
  • 华为OD机试真题Python实现【 不含 101 的数】真题+解题思路+代码(20222023)
  • centos7 搭建ELK(elasticsearch、logstash、kibana)
  • 如何写新闻稿?写好新闻稿的技巧与步骤
  • 抖音不想只做“开心果”
  • MATLAB | 如何用MATLAB绘制这样有气泡感的网络图
  • Linux 远程登录
  • SAP中BOM基础数量及组件数量单位比例关系的注意事项
  • 华为OD机试真题Python实现【最大相连男生数】真题+解题思路+代码(20222023)
  • Vue使用ElementUI对表单元素进行自定义校验
  • linux的文件权限介绍
  • 支付系统中的设计模式03:模板方法模式