题目传送门

题目大意:大家都懂。

思路:

  今天给实验室的学弟学妹们讲的带权并查集,本来不想细讲的,但是被学弟学妹们的态度感动了,所以写了一下这个博客,思想在今天白天已经讲过了,所以直接上代码。

首先,带权并查集必备知识是向量加减规则,不熟悉的可以看我的另外一篇博客(点我

  先放图,模拟的是  x吃y  和x和y同类的向量合并。

这应该是最难的地方,很多东西白天已经讲过了,具体看代码,我写了比较详细的注释。

#include<iostream>
#include<cstdio>
using namespace std;
const int maxn=;
int p=;
//p%3==0 由于下面有向量相减 可能部分value是负的,所以加上一个比较大的数字变成正数
int fa[maxn],n,k,ans,type,x,y,value[maxn];
//value数组 永远记录的都是 当前节点 到fa[x]的权值 此时fa[x]对应的value不一定更新了 ,需要find进行路径合并
//记住 find的功能是找爸爸 + 路径合并 + 更新value[x]
// baba函数的功能是 联合 向量规则更新value
// x->y的权值是1,就是x吃y
int find(int x)
{
if(x==fa[x])return fa[x];
int tep=fa[x]; //先保存当前的还没有路径合并的父节点
fa[x]=find(fa[x]); //把 父节点权值信息更新
value[x]+=value[tep]; //value存的是x到之前的父节点的信息,现在加上 原父节点(tep)合并路径后的权值
return fa[x];
}
void baba(int x,int y,int type)
{
int fx=find(x),fy=find(y);
if(type==) //平级权值为0
{
fa[fx]=fy;
value[fx]=-value[x]+value[y]+; //x的爸爸认y的爸爸当爸爸,用向量规则进行加减
}else{ //x吃y 权值1
fa[fx]=fy;
value[fx]=-value[x]+value[y]+; //x的爸爸认y的爸爸当爸爸,用向量规则进行加减
}
}
int main(){
cin>>n>>k;
for(int i=;i<=n;i++)
{
fa[i]=i;
}
while(k--)
{
scanf("%d%d%d",&type,&x,&y);
if(x>n||y>n||(x==y&&type==)){ //如果标号大于n 或者自己吃自己 肯定错
ans++;
continue;
}
if(find(x)!=find(y)) //如果父亲不同 不在同一集合 肯定不会错 现在合并(因为现在给出的信息已经是限制条件了)
{
baba(x,y,type); //合并的类型是type
}else{
if(type==) //如果是平级的
{
if((value[x]+p)%!=(value[y]+p)%){ //距离根节点的权值 取余3相等才合法(也就是和根节点的相食关系一致)
ans++; //不合法 加加
}
}else{
if((value[x]-value[y]+p)%==||(value[y]-value[x]+p)%==){
//合法就是x吃y,所以要么x比y大1,要么y比x大2(石头剪子布)
}else{
ans++;
}
}
}
}
cout<<ans<<endl;
}

poj1182 食物链 带权并查集的更多相关文章

  1. poj1182(带权并查集)

    题目链接:http://poj.org/problem?id=1182 题意:题目告诉有  3  种动物,互相吃与被吃,现在告诉你  m  句话,其中有真有假,叫你判断假的个数  (  如果前面没有与 ...

  2. poj 1182 食物链 带权并查集

    食物链是并查集的进阶运用的一道非常经典的题目. 题目如下: 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1-N编号.每个动物都是A, ...

  3. POJ 1182 食物链 (带权并查集 && 向量偏移)

    题意 : 中文题就不说题意了…… 分析 : 通过普通并查集的整理归类, 能够单纯地知道某些元素是否在同一个集合内.但是题目不仅只有种类之分, 还有种类之间的关系, 即同类以及吃与被吃, 而且重点是题目 ...

  4. POJ-1182(经典带权并查集)

    食物链 POJ-1182 一个很好的分析博客:https://blog.csdn.net/niushuai666/article/details/6981689 三种关系:两者同类,吃父节点,被父节点 ...

  5. 并查集——poj1182(带权并查集高阶)

    题目链接:食物链 题解:点击 说一声:这题关系推导值得学习.

  6. 【POJ1182】 食物链 (带权并查集)

    Description 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1-N编号.每个动物都是A,B,C中的一种,但是我们并不知道它到 ...

  7. poj1182食物链,经典带权并查集

    动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1-N编号.每个动物都是A,B,C中的一种,但是我们并不知道它到底是哪一种. 有人用两种 ...

  8. poj1182 食物链(带权并查集)

    题目链接 http://poj.org/problem?id=1182 思路 前面做的带权并查集的权值记录该结点与其父结点是否是同一类,只有两种取值情况(0,1),在这题中某结点a和其父结点b的取值共 ...

  9. 【带权并查集】poj1182 食物链

    带权并查集,或者叫做种类并查集,经典题. http://blog.csdn.net/shuangde800/article/details/7974668 这份代码感觉是坠吼的. 我的代码是暴力分类讨 ...

随机推荐

  1. 反射01 Class类的使用、动态加载类、类类型说明、获取类的信息

    0 Java反射机制 反射(Reflection)是 Java 的高级特性之一,是框架实现的基础. 0.1 定义 Java 反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对 ...

  2. Why does my Authorize Attribute not work?

    the roles of a ClaimsPrincipal are actually just claims create with a type of ClaimsIdentity.RoleCla ...

  3. 黑盒测试实践--Day3 11.27

    黑盒测试实践--Day3 今天完成任务情况: 收到小组紧急通知,作业要求更新了.组长召集大家在下午课后去开个短会,会议信息如下: 时间:11.27 晚上5:30 地点:东九楼501 会议内容: 学习了 ...

  4. Sql语句摘要

    1.分批更新数据库 declare @x intset @x=1 while(@x<=51) begin begin tran update UserFavorite set UserFavor ...

  5. 搭建自己的git服务器--gogs

    //@desn:搭建自己的git服务器--gogs //@desn:码字不宜,转载请注明出处 //@author:张慧源  <turing_zhy@163.com> //@date:201 ...

  6. vs调试的时候debug和release的区别

    今天在VS项目中调式遇到一个问题,断点快速查询变量的发现变两竟然不存在 花了一个小时到处百度也查不出一个所以然,后来请教了大神才知道VS调试有debug和release两个模式, vs中的程序有deb ...

  7. android和.net webservice中的DES加密算法

    也是看了一堆的例子,本身并不会写加密算法,好在只要会用就行了,我们把在app中使用的参数加密,然后在.net端的webservice中进行解密,本身并没有什么问题,但是android下和.net下的d ...

  8. Redis缓存穿透、缓存雪崩

    缓存穿透 缓存穿透是指查询一个一定不存在的数据,由于缓存是不命中时被动写的,并且出于容错考虑,如果从存储层查不到数据则不写入缓存,这将导致这个不存在的数据每次请求都要到存储层去查询,失去了缓存的意义. ...

  9. Win7 WPF程序无法接受外部拖拽

    最近在WPF项目中遇到一个问题.虽然选择了AllowDrop = True,但是还是无法支持从外部拖拽文件到程序,倒是内部拖拽(如从一个列表拖拽到树)和从程序拖拽到外部可以. 解决过程 1.考虑是程序 ...

  10. 【连载】redis库存操作,分布式锁的四种实现方式[二]--基于Redisson实现分布式锁

    一.redisson介绍 redisson实现了分布式和可扩展的java数据结构,支持的数据结构有:List, Set, Map, Queue, SortedSet, ConcureentMap, L ...