C++: 背包问题

本文介绍了使用C++解决背包问题的方法,通过循环内递归配合回溯策略,遍历所有可能的物品组合,寻找恰好装满背包的解。在实现过程中,注意对临时变量temp的管理以及何时更新总和sum。
摘要由CSDN通过智能技术生成

题目:
背包问题:假设有一个能装入总体积为T的背包和n件体积分别为W1,W2,…,Wn的物品,能否从n件物品中挑选若干件恰好装满背包,使Wi1+Wi2+…+Win=T,要求找出所有满足上述条件的解。

思路:
采用循环内调用递归的方式,同时利用回溯的思想,将情况遍历一遍并取出符合条件的输出。

代码:

# include <iostream>
# include <vector>
using namespace std;

int sum = 0;  // The sum of all items
int T; // The volumn of bag
int count1 = 0; // The number of conditio
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值