#383 Div1 Problem B Arpa's weak amphitheater.... (分组背包 && 并查集)
题意 : 有n个人,每个人都有颜值bi与体重wi。剧场的容量为W。有m条关系,xi与yi表示xi和yi是好朋友,在一个小组。 每个小组要么全部参加舞会,要么参加人数不能超过1人。 问保证总重量不超过W,剧场中的颜值最大能到多少?
分析 : 很显然的分组背包题目, 不过有所不同, 先来回顾一下普通的分组背包的描述 给出一个背包,背包有容量C,再给出N组物品,每组物品有ki种,每种物品有对应的体积Vi,价值Pi,每组物品至多选一种,且最多取一件。求用背包装物品,能获得的最大总价值是多少。可以发现和上面的不同之处就是多了一个可以全取的操作, 其实只要再在每一组里面加上所有的物品和就行了, 便成了一道普通的模板题了!在分组的时候使用简单的并查集即可!
瞎搞 : 在实现的时候很慢, 还老是犯小错误, 归其原因就是分组背包接触太少, 即使是模板题也写的有点不流利!
#include<bits/stdc++.h> using namespace std; struct st { int w, v, id; }; st arr[]; ][], w[][], dp[], p[];///p数组表示各个组里面的物品个数 ], sumw[]; ]; map<int, int> M; int findset(int x) { int root = x; while(c[root] != root) root = c[root]; int j; while(c[x] != root){ j = c[x]; c[x] = root; x = j; } return root; } inline int join(int a, int b) { int f = findset(a), ff = findset(b); if(f != ff){ c[f] = ff; } } #define IN 0 #define OUT 0 int main(void) { #if IN freopen("in.txt", "r", stdin); #endif #if OUT freopen("out.txt", "w", stdout); #endif int n, m, C; scanf("%d%d%d", &n, &m, &C); M.clear(); ; i<=n; i++){ memset(v[i], , sizeof(v[i])); memset(w[i], , sizeof(w[i])); memset(p, , sizeof(p)); memset(dp, , sizeof(dp)); memset(sumw, , sizeof(sumw)); memset(sumv, , sizeof(sumv)); arr[i].id = i;//忽略这个id, 没有用, 懒得改了..... c[i] = i; } ; i<=n; i++) scanf("%d", &arr[i].w); ; i<=n; i++) scanf("%d", &arr[i].v); ; i<m; i++){ int a, b; scanf("%d%d", &a, &b); join(a, b); } ;///表示组数 ]; memset(vis, true, sizeof(vis)); ; i<=n; i++){ int temp = findset(i); if(vis[temp]){///如果还没有出现过这个在并查集里面的“大佬” M[temp] = top;//记录一下老大所在的组的下标元素 vis[temp] = false; v[top][p[top]] = arr[i].v; w[top][p[top]] = arr[i].w; sumv[top] += arr[i].v; sumw[top] += arr[i].w; p[top]++, top++; }else{ int Top = M[temp]; v[Top][p[Top]] = arr[i].v; w[Top][p[Top]] = arr[i].w; sumv[Top] += arr[i].v; sumw[Top] += arr[i].w; p[Top]++; } } ; i<top; i++){ ) continue;//这里需要注意, 只有一个元素的时候, 不应该再加所有元素的和, 会重复的! v[i][p[i]] = sumv[i]; w[i][p[i]] = sumw[i]; p[i]++; } ///Debug begin // printf("top = %d\n", top); // for(int i=0; i<top; i++){ // printf("In group %d\n", i); // printf("v");puts(""); // for(int j=0; j<p[i]; j++){ // printf("ord=%d, v=%d\n", j, v[i][j]); // } // printf("w");puts(""); // for(int j=0; j<p[i]; j++){ // printf("ord=%d, w=%d\n", j, w[i][j]); // } // puts(""); // } // puts(""); ///Debug end ; i<top; i++){ ; j--){ ; k<p[i]; k++){ if(w[i][k] <= j) dp[j] = max(dp[j], dp[j-w[i][k]]+v[i][k]); } } ///Debug begin // for(int ii=1; ii<=C; ii++){ // printf("%d ", dp[ii]); // } // puts(""); ///Debug end } printf("%d\n", dp[C]); ; }
#383 Div1 Problem B Arpa's weak amphitheater.... (分组背包 && 并查集)的更多相关文章
- Codeforces Round #383 (Div. 2) D. Arpa's weak amphitheater and Mehrdad's valuable Hoses(分组背包+dsu)
D. Arpa's weak amphitheater and Mehrdad's valuable Hoses Problem Description: Mehrdad wants to invit ...
- Codeforces Round #383 (Div. 2) D. Arpa's weak amphitheater and Mehrdad's valuable Hoses —— DP(01背包)
题目链接:http://codeforces.com/contest/742/problem/D D. Arpa's weak amphitheater and Mehrdad's valuable ...
- Codeforces Round #383 (Div. 2)D. Arpa's weak amphitheater and Mehrdad's valuable Hoses(dp背包+并查集)
题目链接 :http://codeforces.com/contest/742/problem/D 题意:给你n个女人的信息重量w和美丽度b,再给你m个关系,要求邀请的女人总重量不超过w 而且如果邀请 ...
- Arpa's weak amphitheater and Mehrdad's valuable Hoses
Arpa's weak amphitheater and Mehrdad's valuable Hoses time limit per test 1 second memory limit per ...
- B. Arpa's weak amphitheater and Mehrdad's valuable Hoses
B. Arpa's weak amphitheater and Mehrdad's valuable Hoses time limit per test 1 second memory limit p ...
- Codeforces 741B:Arpa's weak amphitheater and Mehrdad's valuable Hoses(01背包+并查集)
http://codeforces.com/contest/741/problem/B 题意:有 n 个人,每个人有一个花费 w[i] 和价值 b[i],给出 m 条边,代表第 i 和 j 个人是一个 ...
- Codeforces 741B Arpa's weak amphitheater and Mehrdad's valuable Hoses
[题目链接] http://codeforces.com/problemset/problem/741/B [题目大意] 给出一张图,所有连通块构成分组,每个点有价值和代价, 要么选择整个连通块,要么 ...
- D. Arpa's weak amphitheater and Mehrdad's valuable Hoses 分组背包模板题
http://codeforces.com/problemset/problem/742/D 并查集预处理出所有关系. 一开始的时候,我预处理所有关系后,然后选择全部的时候,另起了一个for,然后再判 ...
- 【42.86%】【codeforces 742D】Arpa's weak amphitheater and Mehrdad's valuable Hoses
time limit per test1 second memory limit per test256 megabytes inputstandard input outputstandard ou ...
随机推荐
- 反复横跳的瞄准线!从向量计算说起!基于射线检测的实现!Cocos Creator!
最近有小伙伴问我瞄准线遇到各种形状该怎么处理?如何实现反复横跳的瞄准线?最近刚好在<Cocos Creator游戏开发实战>中看到物理系统有一个射线检测,于是,基于这个射线检测,写了一个反 ...
- abp.event.on与abp.event.off使用
apb的全局事件 var eventName = "app.createOrEditFieldModalSaved"; var reloadPage = function () { ...
- 微软宣布加入 OpenJDK,打不过就改变 Java 未来!
近日,微软的 Bruno Borges 在 OpenJDK 邮件列表中发布了一条消息,内容包含接下来发生的事情以及微软如何开始将其团队整合到 OpenJDK 社区. 在邮件中,Bruno Borges ...
- java 不可变对象 final Collections guava 简单样例
本地环境 jdk1.8 连接 Google Guava官方教程(中文版) journaldev 说明 java的final关键字大家都了解,但是final修饰的如果是引用类型,那么不可修改的其实只是重 ...
- 洛谷 P2331 最大子矩阵 题解
题面 对于m==1和m==2两种状态进行不同的dp: 设sum[i][1]表示第一列的前缀和,sum[i][2]表示第二列的前缀和: sum[i][1]=sum[i-1][1]+a[i][1]; su ...
- 不要64 数位DP
Problem Description 杭州人称那些傻乎乎粘嗒嗒的人为62(音:laoer). 杭州交通管理局经常会扩充一些的士车牌照,新近出来一个好消息,以后上牌照,不再含有不吉利的数字了,这样一来 ...
- C++中组合和继承的概念及意义
1,继承在面向对象中具有举足轻重的地位,面向对象当中的很多高级技术都和继承是息息相关的,比如面向对象的高端课程<设计模式>中的每一种技术都和继承有关,因此我们非常有必要在学习 C++ 时, ...
- 初识MySQL <一>
创建一个 表 create table student( id int(10) not null unique auto_increment primary key, name varchar(30) ...
- CentOS 7 安装MongoDB 4.0
1.创建yum源文件 /etc/yum.repos.d/mongodb-org-4.0.repo [mongodb-org-4.0] name=MongoDB Repository baseurl=h ...
- div css 布局对seo 影响 布局原则
一.代码精简 使用DIV+CSS布局,页面代码精简,这一点相信对XHTML有所了解的都知道.代码精简所带来的直接好处有两点:一是提高蜘蛛爬行效率,能在最短的时间内爬完整个页面,这样对收录质量有一定好处 ...