0/1背包问题(递归求解)

2023-11-17

0/1背包问题

0/1背包问题是十分常见的算法,下面我就是我对此问题的分析。

引言

一想到0/1背包问题,首先会想到用递归求解。但此问题的递归不像数学公式中的递归那么简单。首先是此问题的分支比较多,需要判断背包的容量是大于、小于还是等于当前物品的重量。其次就是,普通的递归只对一个对象的规模变小,而此问题要对两个对象的规模都变小

题解

令a[]为各个物品的重量,m为背包容量,n表示第n个物品 。从后往前看,
1.如果当前没有物品,直接返回false。
2.如果当前背包的容量恰为第n个物品的重量,返回true 。
3.如果当第n个物品的重量大于当前背包容量 ,①当前物品为第一个物品,那么肯定找不到,返回false;②当前不是第一个物品,那么就在前n-1个物品中继续找,返回pack(a,n-1,m)。
4.当第n个物品的重量小于当前背包容量,①让背包装下此物品,那么调用pack(a,n-1,m-a[n]);②不让背包装下此物品,那么调用pack(a,n-1,n);二者如有一中情况满足,那么此问题就有解,所以返回二者结果的或。(具体如以下代码)

代码如下:

#include<iostream>
using namespace std;
bool pack(int a[],int n,int m)//a[]为各个物品的重量,m为背包容量,n表示第n个物品 
{
	if(n<0)//没有剩下的物品了 
	{
		return false;
	}
	if(m==a[n])//如果当前背包的容量恰为第n个物品的重量,返回true 
	{
		return true;
	}
	else if(m<a[n])//当第n个物品的重量大于当前背包容量 
	{
		if(n==0)//当第1个物品的重量大于背包容量 
		{
			return false;
		}
		return pack(a,n-1,m);//在前n个物品中求解 
	}
	else//当第n个物品的重量小于当前背包容量
	{
		return pack(a,n-1,m)||pack(a,n-1,m-a[n]);//当a[n]不放背包中或a[n]不放背包中 
	}
}
int main()
{
	int a[6];
	int i,n;
	cin>>n;
	for(i=0;i<6;i++)
	{
		cin>>a[i];
	}
	if(pack(a,5,n))
	{
		cout<<"true"<<endl;
	}
	else
	{
		cout<<"false"<<endl;
	}
	return 0;
 } 

示例结果:
在这里插入图片描述
在这里插入图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

0/1背包问题(递归求解) 的相关文章

随机推荐

  • 基于STM32的智能泊车系统

    一 前言 想起第一次参加的电子设计校赛好像在昨天一样 虽然确实在昨天 但是为了纪念这一段时间的劳动 并且记录一下遇到的问题 所以写了这篇文章 二 实现思路 通过手机向停车场发送停车请求 然后停车场通过判断车位是否为空 控制继电器打开相应的电
  • asp.net zero 8.2 学习-4-创建接口及服务

    上一节 在框架添加了实体 这一节 写接口及服务类 实现实体的增删改查 创建接口 SIS Application Shared层 创建DTO SIS Application Shared层 对应的Dto文件夹 创建Dto映射Mapper SI
  • vue-el-admin 使用?

    一 搭建 下载 启动 下载地址 panjiachen vue el admin Gitee com 共两个版本 vue element admin 完善版 vue admin template 极简版 启动 node js切换版本到16及以
  • STM32——端口复用与重映射

    目录 端口复用的概念 内置外设的概念 端口复用的概念 端口复用的配置 配置示例 串口1 复用GPIO的配置 STM32中文参考手册 110页 端口重映射概念 端口重映射概念 部分重映射 完全重映射 AFIO时钟 开启AFIO情况 重映射端口
  • 用户注册及登录测试用例小记

    用户注册及登录测试用例
  • 更换PostgreSQL的data并重启服务

    更换 PostgreSQL 的 data 文件夹并重新启动 PostgreSQL 服务 适应场景 系统崩溃 需要恢复 PostgreSQL 数据及服务 平时可用的一种 PostgreSQL 备份 还原手段 操作步骤 导出 PostgreSQ
  • @SpringBootApplication注解学习

    SpringBootApplication 组合注解 具有多个注解功能 SpringBootConfiguration Documented 表明这个注解应该被 javadoc工具记录 没什么用 Configuration 表示当前类可以看
  • (ffmpeg)ffmpeg+SDL的简单播放器(雷霄骅)更新版

    代码源自雷神 一个是播放音频的demo 可以播放MP3和AAC 但是MP3应该是没有封面的 另一个是播放ts格式的视频 没有声音 源码可以到雷神博客下载 但是因为ffmpeg库的更新问题 并不能直接在ubuntu下直接运行 笔者做了修改 在
  • 第九周 【项目3 - 利用二叉树遍历思想解决问题】

    Copyright c 2017 烟台大学计算机与控制工程学院 All rights reservrd 作者 赵楷文 完成时间 2017年10月28日 版本号 v1 0 问题描述 利用二叉树遍历思想解决问题 一 头文件 btree h 包含
  • 支付宝、微信、银联三种支付平台链接

    1 申请支付宝需要的资料 支付宝移动开发平台 1 单位营业执照彩色扫描件或数码照片 2 组织机构代码证彩色扫描件或数码照片 3 对公银行账户 基本账户 一般账户均可 4 法定代表人的身份证彩色扫描件或数码照片 若为代理人 即法人以外的公司代
  • Redis(三)分布式应用

    一 分布式支持 1 性能 Redis本身的QPS已经很高了 但是如果在一些并发量非常高的情况下 性能还是会受到影响 这个时候我们希望有更多的Redis服务来分摊压力 实现负载均衡 2 高可用 如果只有一个Redis服务 一旦服务宕机 那么所
  • 解决在安装vue-cli脚手架出现的问题

    今天下载安装vue cli脚手架的时候 出现如下问题 刚开始我还以为是我曾经下载过vue cli 然后我便去执行卸载的命令 事实证明我从未下载过vue cli脚手架 下面我就记录一下我自己的解决方法 npm WARN deprecated
  • 关于遗传算法

    关于遗传算法 有很多袋鼠 它们降落到喜玛拉雅山脉的任意地方 这些袋鼠并不知道它们的任务是寻找珠穆朗玛峰 但每过几年 就在一些海拔高度较低的地方射杀一些袋鼠 于是 不断有袋鼠死于海拔较低的地方 而越是在海拔高的袋鼠越是能活得更久 也越有机会生
  • ZooKeeper面试题(2020最新版,狂神说docker进阶笔记

    这里 process 主要就是通过 ServerCnxn 对应的 TCP 连接发送 Watcher 事件通知 9 客户端回调 Watcher 客户端 SendThread 线程接收事件通知 交由 EventThread 线程回调 Watch
  • 如何在EngineeringVillage(EI Compendex)检索中文期刊

    工作环境 蓝色粗体字为特别注意内容 1 系统环境 Win7 Ultimate sp1 2 软件环境 Google Chrome浏览器 3 参考文献 https info b2b168 com s168 51687540 html 有时候我们
  • 官网下载python,下载pycharm

    一 下载python 访问python官网 https www python org downloads 点击 Downloads Windows 选择要下载的历史版本 点击 保存本地路径即可完成下载 二 下载pycharm 访问pycha
  • 结构体大小计算

    求结构体的大小是我们面试经常考察的一个问题 必须熟练的掌握 首先我们必须懂结构体的内存对齐规则 如下 1 第一个成员在与结构体变量偏移量为0的地址处 2 其他成员变量要对齐到某个数字 对齐数 的整数倍的地址处 对齐数 编译器默认的对齐数 v
  • Unittest 之 DDT 的原理解析

    引言 前面的文章介绍了如何在 Python 的 Unittest 框架中来使用 ddt 实现数据驱动的自动化测试 在了解了 ddt 的使用后 你是否有过如下疑问 ddt 是如何把你的测试数据转换传给你的测试用例 当你的一组数据有多个参数时
  • 损失函数(IoU、GIoU、DIoU、CIoU)

    一 IoU 1 笔记原页 IoU Loss 1 IoU 2 IOU优缺点 目标检测中常常用iou来衡量proposal或anchor和gt之间的重合度 也就是他们之间的交并比 是目标检测中重要的评价尺度 鲜明的特点就是对尺度scale不敏感
  • 0/1背包问题(递归求解)

    0 1背包问题 0 1背包问题是十分常见的算法 下面我就是我对此问题的分析 引言 一想到0 1背包问题 首先会想到用递归求解 但此问题的递归不像数学公式中的递归那么简单 首先是此问题的分支比较多 需要判断背包的容量是大于 小于还是等于当前物