C\C++洛谷P1776宝物筛选

这篇博客介绍了如何使用C++解决洛谷P1776题——宝物筛选,这是一个结合01背包、完全背包、多重背包的混合问题。博主分享了初始思路及通过二进制拆分进行优化的方法,以求在不超过手推车承重限制的情况下,最大化宝物的总价值。文章适合有一定DP基础的读者阅读,并欢迎大家指出错误和建议。
摘要由CSDN通过智能技术生成

宝物筛选(混合背包)

前言:请读者在已知01背包、完全背包的推导过程,且有一定的DP基础的前提下,再来阅读本文,效果更佳。

题意:

小FF找到了N件宝物,每一件都有它的价值、重量、数量,小FF当然想全部拿走,但它有一个拉跨的 手推车,只能承受M的重量。求在重量不超过M的前提下,拿到的宝物价值最大!!!

输入:

第一行为N、M,接下来的N行为每一件宝物的价值、重量、数量。

输出:

最大价值!!!


思路:

大家应该都能看出来是一个混合背包:即集01背包、完全背包、多重背包于一身的杂交体,这类问题我们的普遍做法如下,但这个做法有一个很大的缺点:太慢了。

//我把这个做法称为:分类讨论法
#include<iostream>
#define ll long long
#define ull unsigned long long
#define INF 0x3f3f3f3f
using namespace std;
int n,m,f[50000];
int main()
{
   
	cin >> n >> m;
	for(int i = 1,w,c,p;i <= n;++i)
	{
   
		cin >> c >> w >> p;
		if(p == 1)//01背包
		{
   
			for(int j = m;j >= w;--j)
			{
   
				f
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值