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

动态规划之 “完全背包“ ------P8646 [蓝桥杯 2017 省 AB] 包子凑数

文章目录

  • 前言
  • 一、例题
  • 二、分析题意
  • 三、代码示例
  • 总结


前言

今天讲一道蓝桥真题
需要的前置知识点是完全背包,如果对此知识点不懂可以点击此处了解代码随想录之完全背包

现在我们有了这个前置知识点后直接开始看题


一、例题

在这里插入图片描述

二、分析题意

其实这就是一个完全背包问题,每个物品可以无限次数的拿取,当然,一个纯的完全背包问题问的是一个j容量的背包在对于一些物品无限次拿取的时候最大价值为多少,这道题我们要求的不是最大价值,而是背包是否可以被装满,比如我的背包容量为5,如果dp[5]=5说明可以被装满,按照题目的意思就是可以凑出5这个数

那什么时候是INF无限个数呢?其实我们开数据范围就能知道,我们只需要开一个较大的dp数组即可

dp状态转移公式
dp[j]=max(dp[j],dp[j-value[i]]+value[i])

我们在求完全背包的问题,在遍历背包的时候一定是正序遍历的,因为一件物品可以多次拿取,如果这里还有疑惑,说明前置知识点并没有理解透彻,请点击前言部分的链接学习完01背包一维dp完全背包问题后再解决此题目

三、代码示例

#include<iostream>
using namespace std;
int n;
int value[110];
int dp[1000005];//背包容量为i能装的最大价值为dp[i]
int main()
{
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		cin>>value[i];
	}
	
	for(int i=1;i<=n;i++)//遍历物品
	{
		for(int j=value[i];j<=1000000;j++)//正序遍历背包 因为一件物品可以被多次拿取
		{
			dp[j]=max(dp[j],dp[j-value[i]]+value[i]);
		}
	}
	
	int ans=0;
	for(int i=1;i<=1000000;i++)
	{
		if(dp[i]==0||dp[i]!=i)
		{
			ans++;//记录凑不出数的个数
		}
	}
	
	if(ans>=500000)cout<<"INF";//如果有500000个数凑不出 那基本上就是无限了
	else
	{
		cout<<ans;//否则直接输出多少个数不可以被凑出
	}
	return 0;
}

总结

学习路线: 二维01背包-----一维01背包------完全背包


http://www.kler.cn/a/572375.html

相关文章:

  • CISC架构
  • Rust 并发编程:Futures、Tasks 和 Threads 的结合使用
  • Flutter_学习记录_本地存储数据
  • 玩转大语言模型——Ubuntu系统环境下使用llama.cpp进行CPU与GPU混合推理deepseek
  • 人工智能 大模型在物联网感知层上的应用
  • Go与PHP性能对比分析
  • Linux系列:如何调试 malloc 的底层源码
  • Excel基础(详细篇):总结易忽视的知识点,有用的细节操作
  • 【JSON与JSONP】JSON与JSONP全面解析:定义、区别与核心技术对比
  • 初识uniApp
  • 计算机网络-实验四子网划分
  • 【文献阅读】The Efficiency Spectrum of Large Language Models: An Algorithmic Survey
  • 高频 SQL 50 题(基础版)_1174. 即时食物配送 II
  • 使用GitLink个人建站服务部署Allure在线测试报告
  • Windows逆向工程入门之MASM字符处理机制
  • HarmonyOS学习第14天:深入剖析Ability组件
  • MyBatis-Plus 逻辑删除实现
  • 【Java面试】重载(Overload)和 重写(Override)的区别
  • Bruno运行登录接口遇到报错canot found module ‘htmlparser2’怎么解决
  • OpenHarmony多模输入子系统