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

蓝桥杯备考----》完全背包模板

其实这个完全背包的步骤和01背包也是差不多滴,不过他有一些优化是我们必须要说一说的

老样子,我们先定义一下状态表示

step1: f[i][j]表示从1到i个物品里选出体积不超过j的最大价值

step2:状态转移方程

写成一行就是

我们再写一下f[i][j-v[i]]的表达式

可以推出f[i][j]其实就是等于max(f[i-1][j],f[i][j-v[i]+w[i])

这就是我们优化后的状态转移方程,很简单

step3:初始化,全部初始化为0

step4:结果就存在f[n][V]里

#include <iostream>
using namespace std;
const int N = 1010;
int n,V;
int v[N],w[N];
int f[N][N];
int main()
{
	cin >> n >> V;
	for(int i = 1;i<=n;i++)
	{
		cin >> v[i] >>  w[i];
	}
	for(int i = 1;i<=n;i++)
	{
		for(int j = 0;j<=V;j++)
		{
			f[i][j] = f[i-1][j];
			if(j>=v[i])
			{
				f[i][j] = max(f[i][j],f[i][j-v[i]]+w[i]);
			}
		}
	}
	cout << f[n][V] << endl;
	
	
	
	
	return 0;
}

嗯,我们还需要想一想这个代码怎么进行空间优化可以看到,我们更新一维数组的时候,我们需要当前位置和左边位置的元素,所以我们必须得先把左边位置更新出来才行,所以我们必须从左往右更新才正确

优化代码

#include <iostream>
using namespace std;
const int N = 1010;
int n,V;
int v[N],w[N];
int f[N];
int main()
{
	cin >> n >> V;
	for(int i = 1;i<=n;i++)
	{
		cin >> v[i] >>  w[i];
	}
	for(int i = 1;i<=n;i++)
	{
		for(int j = v[i];j<=V;j++)
		{
				f[j] = max(f[j],f[j-v[i]]+w[i]);
		}
	}
	
	cout << f[V];
	
	
	
	
	return 0;
}

好的好的,那我们来继续做一下第二问

step1:定义状态表示 f[i][j]表示的是从1到i个物品里选出恰好体积为j的物品的最大价值

step2:定义状态表示,和上面的一样

step3:初始化,全部初始化为负无穷,因为我们要用到max,不能让坏值影响我们的推导

并单独把f[0][0]设置为0

step4:答案如果存在的话就存在f[n][V]

#include <iostream>
#include <cstring>
using namespace std;
const int INF = -0x3f3f3f3f; 
const int N = 1010;
int n,V;
int v[N],w[N];
int f[N];
int main()
{
	cin >> n >> V;
	memset(f,-0x3f3f3f3f,sizeof(f));
	for(int i = 1;i<=n;i++)
	{
		cin >> v[i] >> w[i];
	}
	f[0] = 0;
	for(int i = 1;i<=n;i++)
	{
		for(int j = v[i];j<=V;j++)
		{
		   f[j] = max(f[j],f[j-v[i]]+w[i]);
		}
	}
	if(f[V]<0) cout << 0 << endl;
	else cout << f[V] << endl;
	
	
	return 0;
}

相关文章:

  • HarmonyOs学习 实验四:开发一个登录界面
  • Electron 系统托盘与屏幕捕捉深度解析:从基础到企业级实践
  • 【Linux】网络概念
  • STM32F103_LL库+寄存器学习笔记13 - 梳理外设CAN与如何发送CAN报文(串行发送)
  • [Vue2]侦听器watch(监视器)
  • Android JobScheduler调度任务面试题及参考答案
  • 01_现代C++特殊成员函数
  • Android 10上如何查看GPU占用率 安卓手机怎么看gpu频率
  • 介绍一下JVM内存结构面试回答(后续会继续补充)
  • Netty源码—10.Netty工具之时间轮
  • QT 动态布局实现(待完善)
  • 【docker】Dockerfile中ENTRYPOINT和CMD区别理解
  • c语言strcat和strlen的注意事项
  • 实现分布式锁的方案与实战应用案例
  • PP-ChatOCRv3新升级:多页PDF信息抽取支持自定义提示词工程,拓展大语言模型功能边界
  • 【深度学习新浪潮】什么是推理模型?
  • spring boot中“编程式事务”与“声明式事务”对比
  • day18 学习笔记
  • leetcode146.LRU缓存
  • 全球消费理性化浪潮下:跨境电商品牌溢价体系面临重构
  • 高端网站建设机构/常用的网络营销方式
  • 创业网站建设政策/app推广软文范文
  • 不买域名怎么做网站/今日头条新闻推荐
  • 外贸 需要到国外建网站吗/百度官方电话号码
  • 微网站用什么做/百度小程序入口官网
  • 如何在网站上做免费广告/百度热搜榜在哪里看