news 2026/5/15 10:16:59

[特殊字符] 背包问题详解(0/1 背包、完全背包、多重背包)——附 C++ 实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
[特殊字符] 背包问题详解(0/1 背包、完全背包、多重背包)——附 C++ 实现

🧳 背包问题详解(0/1 背包、完全背包、多重背包)——附 C++ 实现

一、什么是背包问题?

背包问题(Knapsack Problem)是经典的动态规划问题之一:

给定一个容量有限的背包和若干物品,每个物品有体积(或重量)*和*价值,问如何选择物品使得总价值最大**。

根据每个物品可选次数不同,背包问题主要分为:

  • 0/1 背包(每个物品最多选一次)
  • 完全背包(每个物品可以选无限次)
  • 多重背包(每个物品有固定数量)

二、0/1 背包问题

1️⃣ 问题描述

  • 背包容量:W
  • 物品数量:n
  • i个物品:
    • 重量:w[i]
    • 价值:v[i]
  • 每个物品最多选一次

目标:
👉 在不超过背包容量的前提下,使总价值最大。


2️⃣ 状态定义

令:

dp[j] = 容量为 j 时能获得的最大价值

3️⃣ 状态转移方程

对于第i个物品:

dp[j] = max(dp[j], dp[j - w[i]] + v[i])

⚠️关键点
j必须从大到小遍历,防止一个物品被选多次。


4️⃣ C++ 实现(0/1 背包)

#include<bits/stdc++.h>usingnamespacestd;intmain(){intn,W;cin>>n>>W;vector<int>w(n),v(n);for(inti=0;i<n;i++){cin>>w[i]>>v[i];}vector<int>dp(W+1,0);for(inti=0;i<n;i++){for(intj=W;j>=w[i];j--){dp[j]=max(dp[j],dp[j-w[i]]+v[i]);}}cout<<dp[W]<<endl;return0;}

三、完全背包问题

1️⃣ 问题描述

与 0/1 背包类似,但:

每个物品可以选无限次


2️⃣ 状态转移区别

dp[j] = max(dp[j], dp[j - w[i]] + v[i])

⚠️关键区别
j必须从小到大遍历,允许多次使用当前物品。


3️⃣ C++ 实现(完全背包)

#include<bits/stdc++.h>usingnamespacestd;intmain(){intn,W;cin>>n>>W;vector<int>w(n),v(n);for(inti=0;i<n;i++){cin>>w[i]>>v[i];}vector<int>dp(W+1,0);for(inti=0;i<n;i++){for(intj=w[i];j<=W;j++){dp[j]=max(dp[j],dp[j-w[i]]+v[i]);}}cout<<dp[W]<<endl;return0;}

四、多重背包问题

1️⃣ 问题描述

  • 每个物品最多只能选k[i]

2️⃣ 常见解决方法

✅ 方法一:暴力枚举(不推荐)

三重循环,时间复杂度高。

✅ 方法二:二进制拆分(推荐)

k个物品拆成:

1, 2, 4, ..., 剩余

然后转化为0/1 背包问题


3️⃣ C++ 实现(二进制优化)

#include<bits/stdc++.h>usingnamespacestd;intmain(){intn,W;cin>>n>>W;vector<int>dp(W+1,0);for(inti=0;i<n;i++){intw,v,k;cin>>w>>v>>k;for(intc=1;k>0;c<<=1){intnum=min(c,k);k-=num;intweight=num*w;intvalue=num*v;for(intj=W;j>=weight;j--){dp[j]=max(dp[j],dp[j-weight]+value);}}}cout<<dp[W]<<endl;return0;}

五、三种背包对比总结

类型每件物品j 遍历方向本质
0/1 背包最多 1 次从大到小防止重复选
完全背包无限次从小到大允许重复
多重背包有上限转化为 0/1二进制优化

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/15 8:13:56

快速排序的理解与实践(c语言实现)

快速排序的理解与实践 排序是计算机程序中常见的操作&#xff0c;而快速排序以其高效性成为许多程序员的优先选择。第一次接触快速排序时&#xff0c;我被它巧妙的分治思想所吸引——将一个大问题分解为若干小问题&#xff0c;逐个解决后再合并结果。这种思维方式不仅适用于排序…

作者头像 李华
网站建设 2026/5/13 18:16:56

Product Hunt 每日热榜 | 2025-12-14

1. PlanEat AI 标语&#xff1a;人工智能将你的健康目标变成一个为期7天的菜单和购物清单。 介绍&#xff1a;大多数应用程序给你提供一堆食谱&#xff0c;而聊天机器人则让你淹没在文字中。PlanEat AI 将你的健康数据和饮食规则整理成一个可行的每周计划和分类购物清单&…

作者头像 李华
网站建设 2026/5/13 12:26:04

实验实验实验

这玩意儿直接html吗&#xff0c;前端和后端直接连接&#xff0c;直接打包。我可以理解为这是专属小程序的debug&#xff0c;必须要有源代码。

作者头像 李华
网站建设 2026/5/11 19:43:23

二叉搜索树详解:从原理到实战

文章目录一、什么是二叉搜索树&#xff08;BST&#xff09;&#xff1f;二、BST 的基本操作1. 节点定义2. 查找操作3. 插入操作4. 删除操作三、经典例题分析例题 1&#xff1a;验证二叉搜索树&#xff08;LeetCode 98&#xff09;例题 2&#xff1a;二叉搜索树的最近公共祖先&a…

作者头像 李华
网站建设 2026/5/11 19:43:40

后端学习第二周

IO流 IO流&#xff1a; 存储和读取数据的解决方案用于读写文件中的数据&#xff08;可以读写文件&#xff0c;或网络中的数据…&#xff09;输入流读取本地文件中的数据&#xff0c;输出本地文件中的数据 字节&#xff08;符&#xff09;输入流负责读取数据&#xff0c;字节&am…

作者头像 李华