HDU 4341 Gold miner(分组背包)

题目链接 Gold miner

目标是要在规定时间内获得的价值总和要尽可能大。

我们先用并查集把斜率相同的物品分在同一个组。

这些组里的物品按照y坐标的大小升序排序。

如果组内的一个物品被选取了,那该组排在他前面的所有物品肯定被选取了。

那么我们对每个组的所有物品,对价值和代价分别求前缀和。

那么选了3号,就相当于选了1,2,3号。

这个时候问题就转化为分组背包了。

也就是说把物品转换后,这个组内我最多只能选1个物品。

然后就很简单了。

#include <bits/stdc++.h>

using namespace std;

#define rep(i, a, b)	for (int i(a); i <= (b); ++i)
#define dec(i, a, b)	for (int i(a); i >= (b); --i)

typedef long long LL;

const int N = 205;

struct node{ int x, y, t, v; } a[N];

int father[N], used[N], c[N], f[N], g[N], dp[N * N];
int n, t, cnt, et, ca = 0;
vector <int> v[N];

int getfather(int x){ return father[x] ? father[x] = getfather(father[x]) : x; }
bool cmp(int p, int q){ return a[p].y < a[q].y;}

int main(){

	while (~scanf("%d%d", &n, &t)){
		rep(i, 1, n) scanf("%d%d%d%d", &a[i].x, &a[i].y, &a[i].t, &a[i].v);
		memset(father, 0, sizeof father);

		rep(i, 1, n - 1){
			rep(j, i + 1, n){
				if (a[i].x * a[j].y == a[i].y * a[j].x){
					int fa = getfather(i), fb = getfather(j);
					if (fa ^ fb){
						father[fa] = fb;
					}
				}
			}
		}

		rep(i, 1, n) c[i] = getfather(i);

		rep(i, 0, n + 1) v[i].clear();
		cnt = 0;
		memset(used, 0, sizeof used);
		rep(i, 1, n){
			if (!used[c[i]]){
				used[c[i]] = ++cnt;
				v[cnt].push_back(i);
			}

			else{
				v[used[c[i]]].push_back(i);
			}
		}

		rep(i, 1, cnt) if ((int)v[i].size() > 1) sort(v[i].begin(), v[i].end(), cmp);
		
		memset(dp, 0, sizeof dp);
		rep(i, 1, cnt){
			dec(j, t, 0){
				int C = 0, V = 0;
				for (auto u : v[i]){
					C += a[u].t;
					V += a[u].v;
					if (j >= C) dp[j] = max(dp[j], dp[j - C] + V);
				}
			}
		}
		printf("Case %d: %d\n", ++ca, dp[t]);	
	}
	return 0;
}

 

转载于:https://www.cnblogs.com/cxhscst2/p/7360323.html

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 、4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、下载 4使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合;、 4下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.m或d论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 、1资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值