Time Limit: 1 second

Memory Limit: 128 MB

【问题描述】

【背景】

Wind设计了很多机器人。但是它们都认为自己是最强的,于是,一场比赛开始了~

【问题描述】

机器人们都想知道谁是最勇敢的,于是它们比赛搬运一些物品。

它们到了一个仓库,里面有n个物品,每个物品都有一个价值Pi和重量Wi,但是有些物品放在一起会爆炸,并且爆炸具有传递性。

(a和b会爆炸、b和c会爆炸则a和c会爆炸)机器人们可不想因此损失自己好不容易从Wind那里敲诈来的装备,于是它们想知道在

能力范围内,它们最多可以拿多少价值的物品。

你能帮助它们吗?

【输入格式】

每组测试数据

第1行为n,Wmax,k(0<=n,Wmax,k<=1000)

接下来n行,为每个物品的Pi,Wi(0<=Pi<=1000,1<=Wi<=10,均为整数)

再接下来k行,每行2个数字a,b表示a和b会发生爆炸

【输出格式】

对每组数据输出1行

为最大可能价值

Sample Input

3 10 1
100 1
200 5
10 5
1 2

Sample Output

   210

【题解】

a和b会发生爆炸。即a,b中只能选一个。也即分组背包问题。

首先,如果x和y会发生爆炸就把x和y合并在一起(并查集),然后根据合并的情况构造出k组物品。每组中都只能选取一个物品。

然后先for k组背包。表示按照组的顺序进行背包的操作。

然后是for 容量。表示接下来为j容量选取一个物品。

然后是for第k组物品中的具体每一个物品。

因为先for的是容量。所以可以保证。只会选取第k组物品中的一个物品。

最后输出答案即可。

【代码】

#include <cstdio>

int fa[1001],n,wmax,k,c[1001],w[1001],f[1001],next[1001],first[1001],what[1001],num = 0;

int findfather(int x) //用来寻找根节点,同时路径压缩
{
if (fa[x] != x)
fa[x] = findfather(fa[x]);
return fa[x];
} int main()
{
//freopen("F:\\rush.txt","r",stdin);
scanf("%d%d%d",&n,&wmax,&k);
for (int i = 1;i <= n;i++)
scanf("%d%d",&c[i],&w[i]);
for (int i = 1;i <= n;i++) //并查集数组初始化操作
fa[i] = i;
for (int i = 1;i <= k;i++) //输入k个抵触关系
{
int x,y;
scanf("%d%d",&x,&y);
int r1 = findfather(x),r2 = findfather(y);
if (r1 != r2) //把这两个物品合并在一起,即同一组物品
fa[r2] = r1;
}
for (int i = 1;i <= n;i++) //把所有的子节点指向根节点
findfather(i);
int bo[1001] = {0}; //用来标记某一个物品是哪一组的物品
k = 0;
for (int i =1;i <= n;i++)
if (bo[fa[i]] == 0) //这是第一次出现第k组物品的处理方法
{
k++;
bo[fa[i]] = k;
num++;
next[num] = first[k]; //这里用了邻接表来记录k组物品的每一个物品 为了省空间
what[num] = i;
first[k] = num;
}
else //不是第一次出现则记录就好 可以缩短代码。。想缩短就缩吧。-> 邻接表那段可以不用写两次
{
num++;
next[num] = first[bo[fa[i]]];
what[num] = i;
first[bo[fa[i]]] = num;
}
for (int i = 1;i <= k;i++) //进行分组背包的操作
for (int j = wmax;j >= 0;j--)
{
int temp = first[i]; //这是邻接表读取数据的方法
while (temp != 0)
{
int l = what[temp];
if (j >= w[l]) //如果没有超过背包容量 则进行更新
{
if (f[j] < f[j-w[l]] + c[l])
f[j] = f[j-w[l]] + c[l];
}
temp = next[temp];
}
}
printf("%d",f[wmax]); //最后输出答案。
return 0;
}

【t064】最勇敢的机器人的更多相关文章

  1. vijos 1250 最勇敢的机器人 分组背包+并查集

    P1250最勇敢的机器人 背景 Wind设计了很多机器人.但是它们都认为自己是最强的,于是,一场比赛开始了~ 描述 机器人们都想知道谁是最勇敢的,于是它们比赛搬运一些物品. 它们到了一个仓库,里面有n ...

  2. / Vijos / 题库 /1250 / 最勇敢的机器人

    / Vijos / 题库 /1250 / 最勇敢的机器人 借鉴博客:http://www.cnblogs.com/chty/p/5830516.html 背景 Wind设计了很多机器人.但是它们都认为 ...

  3. vijos1250 最勇敢的机器人

    背景 Wind设计了很多机器人.但是它们都认为自己是最强的,于是,一场比赛开始了~ 描述 机器人们都想知道谁是最勇敢的,于是它们比赛搬运一些物品. 它们到了一个仓库,里面有n个物品,每个物品都有一个价 ...

  4. 【Vijos1250】最勇敢的机器人(并查集,分组背包DP)

    题意:有N个物品,承重上限为M,有K组物品互斥关系,互斥关系有传递性,即1与2互斥,2与3互斥,1与3也互斥 给出每个物品的花费和价值,求承重上限内的最大价值总和 n<=1000,m<=1 ...

  5. 【翻译】用AIML实现的Python人工智能聊天机器人

    前言 用python的AIML包很容易就能写一个人工智能聊天机器人. AIML是Artificial Intelligence Markup Language的简写, 但它只是一个简单的XML. 下面 ...

  6. 3.C#面向对象基础聊天机器人

    基于控制台的简单版的聊天机器人,词库可以自己添加. 聊天机器人1.0版本 源码如下: using System; using System.Collections.Generic; using Sys ...

  7. Python 简易聊天机器人

    聊天机器人 | |-----MySql | |---module--"逻辑运算层" | | | |---ciku--"与词库交互" | | | |---dict ...

  8. java 聊天猜拳机器人

    2016-12-06本随笔记录第一次制作经过,感谢各位大神指导. 工具:eclipse;JAVA JDK; 语言:java 时间:2016.11.23 作者:潇洒鸿图 地址:http://www.cn ...

  9. 用VB实现SmartQQ机器人

    这里为了便于介绍程序设计的流程,更多以代码形式给出,具体可用火狐浏览器的firebug插件来抓包分析,或者用谷歌浏览器的开发者工具进行抓包.抓包地址是:http://w.qq.com 第一步,是二维码 ...

随机推荐

  1. Bitmap-把方形图片处理为圆形

    这个是直接在网上转载的,自己验证可靠 转载自http://my.oschina.net/zhouz/blog/213164 直接贴上代码 import android.graphics.Bitmap; ...

  2. Rotation--控件位置旋转

    今天想要完成一个按钮的动画,也就是随着手势在屏幕上的滑动,让按钮图片跟着旋转.刚开始的思路是,先把图片旋转以后,在把这个图片设置为imagebutton的背景.不过,会发现这个图片经过处理以后一直变形 ...

  3. 2. ZooKeeper的ZAB协议。

    转自:https://blog.csdn.net/en_joker/article/details/78662880 ZooKeeper并没有完全采用Paxos算法,而是使用了一种称为ZooKeepe ...

  4. P2P平台项目建设几点注意事项

    种选择 a.资金池,接入第三方支付,财付通,宝付等,比如一起好 b.第三方资金托管,易宝支付.汇付天下等 c.银行存管,资金放在银行 资金池政策风险,不得不考虑. 每一种模式,技术实现都有变化,需要考 ...

  5. Android Material风格的应用(三)--DrawerLayout

    添加抽屉导航 Android Material风格的应用(一)--AppBar TabLayoutAndroid Material风格的应用(二)--RecyclerViewAndroid Mater ...

  6. POJ 1852 Ants || UVA 10881 - Piotr's Ants 经典的蚂蚁问题

    两题很有趣挺经典的蚂蚁问题. 1.n只蚂蚁以1cm/s的速度在长为L的竿上爬行,当蚂蚁爬到竿子的端点就会掉落.当两只蚂蚁相撞时,只能各自反向爬回去.对于每只蚂蚁,给出距离左端的距离xi,但不知道它的朝 ...

  7. (转)高强度密码管理软件KeePass使用详解

    转自:http://www.ruancan.com/ 算下来,你接触电脑有多久了?从第一次上网,到今天,你一共申请了多少个网站或者软件的帐号?相信这是一个几乎无人能够回答的问题. 无数人面临着这两个问 ...

  8. 洛谷——P1022 计算器的改良

    https://www.luogu.org/problem/show?pid=1022#sub 题目背景 NCL是一家专门从事计算器改良与升级的实验室,最近该实验室收到了某公司所委托的一个任务:需要在 ...

  9. 每日技术总结:Better-scroll应用于弹出层内容滚动

    一.Better-scroll在项目中的应用 Better-scroll这款滚动插件还是很好用的,通常不会有什么问题.但偶尔总会出点意外.今天再次使用better-scroll,记录一下这次顺利的过程 ...

  10. ORACLE RMAN备份及还原 RMAN能够进行增量备份:数据库,表空间,数据文件

    ORACLE RMAN备份及还原   RMAN能够进行增量备份:数据库.表空间.数据文件 仅仅有使用过的block能够被备份成backup set 表空间与数据文件相应关系:dba_data_file ...