比基础的并查集有些进步。

在以下这个链接中有详解:

http://blog.csdn.net/ditian1027/article/details/20804911

对于每两个动物的关系,都是先推与终于的关系,在逆推与还有一个的关系;

num中存的都是与终于节点的关系;

#include<stdio.h>
#include<string.h>
#include<iostream>
using namespace std;
const int maxn=50000+10;
struct node{
int q,num;
}s[maxn];
void qq(int n)
{
for(int i=1;i<=n;i++)
{
s[i].q=i;
s[i].num=0;
}
} int find(int y)
{
if(y==s[y].q)
return y;
int t=s[y].q;
s[y].q=find(s[y].q);
s[y].num=(s[t].num+s[y].num)%3;
return s[y].q;
}
void show(int q,int w,int e)//合并集合
{
int tt=find(q);
int rr=find(w);
s[rr].q=tt;
s[rr].num=(s[q].num-s[w].num+3+(e-1))%3;
} int main()
{
int a,b,n,m,g;
scanf("%d %d",&a,&b);
qq(a);
int ans=0;
while(b--)
{
scanf("%d%d%d",&n,&m,&g);
if(m>a||g>a)
{ans++;continue;}
if(n==2&&m==g)
{ans++;continue;}
if(find(m)==find(g))
{
if(n==1&&s[m].num!=s[g].num) ans++;
if(n==2&&(s[m].num+1)%3!=s[g].num) ans++;
}
else
show(m,g,n);
}
printf("%d\n",ans);
return 0;
}

最新文章

  1. Maven项目导入后打红色X
  2. 附7 turbine
  3. C#课外实践——校园二手平台(技术篇1)
  4. node io.sockt 聊天应用
  5. 一步步学Mybatis-怎么样实现动态SQL查询(6)
  6. KEIL C51高级编程
  7. return;,return false,return true----------浅析
  8. Windows 去掉启动时的放大镜
  9. 〖Groovy〗语言使用贴士(Tips)(转)
  10. Oracle学习笔记_08_字符串连接
  11. 【jQuery】(1)---初次接触Jquery
  12. python同步原语--线程锁
  13. Luogu P4707 重返现世
  14. websocket(三)——基于node sockit.io的即时通讯
  15. HDU 2639 骨头收集者 II【01背包 】+【第K优决策】
  16. linux 后台运行命令
  17. 简述 OAuth 2.0 的运作流程(转)
  18. Jenkins持久化集成使用
  19. python之demo1----改编自turtle.py文件中的demo
  20. 牛客网某比赛 I 小乐乐学博弈 博弈论

热门文章

  1. Java反射机制demo(三)—获取类中的构造函数
  2. 移动端h5下ul实现横向滚动css代码
  3. BZOJ 3130: [Sdoi2013]费用流 网络流 二分 最大流
  4. HTTP首部字段
  5. java的注解
  6. hdu 4452 Running Rabbits 模拟
  7. 使用python解决烦人的每周邮件汇总!
  8. addEventListener 的一些好方法 简单粗暴的说给你
  9. PHP常量定义之define与const对比
  10. Flash Builder 4的快捷方式和调试技巧