01背包优先队列优化

01背包优先队列优化

在这里插入图片描述
在这里插入图片描述
设重量为w,权值为v
则单位重量价值为v / w
设有物品1,物品2
若v1 / w1 < v2 / w2
则说明v2的单位重量价值高
即v1 * w2 < v2 * w1
于是可重载结构体,使得v2 * w1大的优先级高
即:

struct Node {
	LL w, v;
	Node() {};
	Node(LL _w, LL _v) {w = _w, v = _v;}
	friend bool operator < (Node a, Node b) {
		return a.v * b.w < b.v * a.w;
	}
};

重点是本题数据范围
1 <= w <= 100
1 <= v <= 1e9
可见价值与质量相比
价值占主导地位
接着按照贪心的思想
单位重量价值越高的越先装入背包
本题结束

AC代码:

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <queue>

using namespace std;

typedef long long LL;

struct Node {
	LL w, v;
	Node() {};
	Node(LL _w, LL _v) {w = _w, v = _v;}
	friend bool operator < (Node a, Node b) {
		return a.v * b.w < b.v * a.w;
	}
};

LL dp[105];

int main()
{
	LL n, m, w, v;
	while(scanf("%lld%lld", &n, &m) != EOF) {
		priority_queue<Node> q;
		for(int i = 0; i < n; i ++) {
			scanf("%lld%lld", &w, &v);
			q.push(Node(w, v));
		}
		LL ans = 0;
		while(m > 100) {
			ans += q.top().v;
			m -= q.top().w;
			q.pop();
		}
		memset(dp, 0, sizeof(dp));
		while(!q.empty()) {
			w = q.top().w;
			v = q.top().v;
			q.pop();
			for(int i = m; i >= w; i --) {
				dp[i] = max(dp[i], dp[i - w] + v);
			}
		}
		ans += dp[m];
		printf("%lld\n", ans);
	}
	return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值