动态规划01背包问题

01背包问题


问题描述

现有四个物品,小偷的背包总容量为8,怎么可以偷到价值最多的物品(注意:每件物品最多只有一件)

如:

物品编号:1 2 3 4

物品重量:2 3 4 5

物品价值:3 4 5 8

分析

我们记f(k,w):当背包容量为w,现在有k件物品可以偷所能偷到的最大价值那么该问题就是f(4,8)我们根据下图来看一下

很明显这道题的状态转移方程为 f(k-1,w),wk>w(太重放不下),max{f(k-1,w),f(k-1,w-wk)+vk},wk<=w

vk代表的是价值

代码如下:

c 复制代码
#include<bits/stdc++.h>
using namespace std;
int f[5][9]={0};// 定义存储动态规划表的数组,f[i][j]表示前i个物品在容量为j的背包中的最大价值
int w[5]={0,2,3,4,5};// 物品重量数组(0号物品不使用,物品从1开始
int v[5]={0,3,4,5,8};// 物品价值数组(0号物品不使用,物品从1开始)
signed main()
{
	int i,j;
	memset(f,0,sizeof(f));
	for(int i=1;i<=4;i++)// 遍历所有物品
	{
		for(int j=1;j<=8;j++)// 遍历所有背包容量
		{
			if(w[i]>j)// 如果当前物品的重量大于背包容量
			{
				f[i][j]=f[i-1][j];// 当前物品不能放入背包,继承上一个状态的值
			}
			else
			{
				// 当前物品可以放入背包,取不放入和放入背包两种情况的最大值
				f[i][j]=max(f[i-1][j],f[i-1][j-w[i]]+v[i]);
			}
		}
	}
	for(int i=0;i<=4;i++)
	{
        for(int j=0;j<=8;j++)
		{
			// 输出每个状态的最大价值
			cout << "f[" << i << "][" << j << "]=" << f[i][j] << endl;
		} 
	}
	return 0;	
} 
相关推荐
lxl13071 分钟前
学习C++(6)日期类的实现+取地址运算符重载
开发语言·c++·学习
fqbqrr3 分钟前
2602c++,剪切板格式
c++
Howrun7777 分钟前
可调用对象
开发语言·c++
练习时长一年7 分钟前
LeetCode热题100(颜色分类)
算法·leetcode·职场和发展
说文科技14 分钟前
大模型项目实战之dpo微调
人工智能·算法
晚风吹长发21 分钟前
初步了解Linux中的线程概率及线程控制
linux·运维·服务器·开发语言·c++·centos·线程
睡一觉就好了。21 分钟前
归并排序——递归与非递归的双重实现
数据结构·算法·排序算法
酉鬼女又兒30 分钟前
SQL23 统计每个学校各难度的用户平均刷题数
数据库·sql·算法
爱学习的阿磊35 分钟前
模板代码跨编译器兼容
开发语言·c++·算法
毕设源码-钟学长38 分钟前
【开题答辩全过程】以 基于协同过滤推荐算法的小说漫画网站设计与实现为例,包含答辩的问题和答案
算法·机器学习·推荐算法