ZOJ - 3261 逆向并查集
思路:很巧妙的解法。如果按照常规一边读入,一边合并并查集,删边实在没办法做。
首先读入所有的操作,把所有不会被删除的边加入并查集,然后从最后一个操作开始逆向操作,当遇到删边操作,就直接把这条边加入并查集。可以用一个栈保存答案。
注意:当有两个power相同的时候,选择编号更小的。输出之间有空行。
AC代码
#include <cstdio> #include <cmath> #include <cctype> #include <algorithm> #include <cstring> #include <utility> #include <string> #include <iostream> #include <map> #include <set> #include <vector> #include <queue> #include <stack> using namespace std; #pragma comment(linker, "/STACK:1024000000,1024000000") #define eps 1e-10 #define inf 0x3f3f3f3f #define PI pair<int, int> typedef long long LL; const int maxn = 1e4 + 5; int p[maxn], a[maxn]; struct node{ int x, y; }b[maxn<<1]; struct oper{ char s[20]; int x, y; }q[maxn*5]; int find(int x) { return p[x] == x ? x : p[x] = find(p[x]); } void unionset(int x, int y) { int rx = find(x), ry = find(y); if(a[rx] == a[ry]) { //当二者的值相同 if(rx < ry) p[ry] = rx; else p[rx] = ry; } else if(a[rx] < a[ry]) { p[rx] = ry; } else p[ry] = rx; } int main() { int n, m, kase = 0; while(scanf("%d", &n) == 1) { if(kase++) printf("\n"); for(int i = 0; i <= n; ++i) p[i] = i; for(int i = 0; i < n; ++i) scanf("%d", &a[i]); scanf("%d", &m); int x, y; for(int i = 1; i <= m; ++i) { scanf("%d%d", &b[i].x, &b[i].y); if(b[i].x > b[i].y) swap(b[i].x, b[i].y); } int Q; scanf("%d", &Q); getchar(); map<PI, int>ha; char s[30]; for(int i = 1; i <= Q; ++i) { fgets(s, sizeof(s), stdin); if(s[0] == 'd') { sscanf(s, "%s%d%d", &q[i].s, &q[i].x, &q[i].y); if(q[i].x > q[i].y) swap(q[i].x, q[i].y); PI pi = make_pair(q[i].x, q[i].y); ha[pi] = 1; //printf("%s %d %d\n", q[i].s, q[i].x, q[i].y); } else { sscanf(s, "%s%d", &q[i].s, &q[i].x); //printf("%s %d\n", q[i].s, q[i].x); } } //建立并查集 for(int i = 1; i <= m; ++i) { if(!ha.count(make_pair(b[i].x, b[i].y))) { unionset(b[i].x, b[i].y); } } //逆向 stack<int>ans; for(int i = Q; i > 0; --i) { if(q[i].s[0] == 'q') { int r = find(q[i].x); if(a[r] <= a[q[i].x]) ans.push(-1); else ans.push(r); } else unionset(q[i].x, q[i].y); } while(!ans.empty()) { printf("%d\n", ans.top()); ans.pop(); } } return 0; }
如有不当之处欢迎指出!
ZOJ - 3261 逆向并查集的更多相关文章
- zoj 3261 逆向并查集+离线处理
题意:给出一些点,每个点有权值,然后有一些边,相连.无向的.然后有一些操作 链接:点我 query a.表示从a出发的能到达的所有点权值最大的点的编号(相同取编号最小,而且权值要比自己大) desto ...
- ZOJ 3261 Connections in Galaxy War(逆向并查集)
参考链接: http://www.cppblog.com/yuan1028/archive/2011/02/13/139990.html http://blog.csdn.net/roney_win/ ...
- HDU - 4496 City 逆向并查集
思路:逆向并查集,逆向加入每一条边即可.在获取联通块数量的时候,直接判断新加入的边是否合并了两个集合,如果合并了说明联通块会减少一个,否则不变. AC代码 #include <cstdio> ...
- HDU_4496_逆向并查集
http://acm.hdu.edu.cn/showproblem.php?pid=4496 逆向并查集,先读取,然后从后向前join每次保存答案即可. #include<iostream> ...
- 逆向并查集 hrbust 1913
#include<iostream> //由于拆除并查集的方法太难或者没有#include<cstdio> //可以先将所有没有拆的桥连接 再逆向操作 断开变成连接 反向输出# ...
- Connections in Galaxy War (逆向并查集)题解
Connections in Galaxy War In order to strengthen the defense ability, many stars in galaxy allied to ...
- ZOJ3261:Connections in Galaxy War(逆向并查集)
Connections in Galaxy War Time Limit: 3 Seconds Memory Limit: 32768 KB 题目链接:http://acm.zju.edu. ...
- BZOJ 1016 星球大战starwar(逆向-并查集)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1015 题意:给出一个图.每次删掉一个点,求删掉之后连通块个数. 思路:正着做不好做,我们 ...
- HDU 4496 D-City(逆向并查集)
http://acm.hdu.edu.cn/showproblem.php?pid=4496 题意: 给出n个顶点m条边的图,每次选择一条边删去,求每次删边后的连通块个数. 思路: 离线处理删边,从后 ...
随机推荐
- _0_web_基础
创:18_3_2017修:20_3_2017 什么是前端? --在浏览器中展示内容以及处理请求 什么是浏览器? --一款能将网页内容展现给用户查看,并且让用户与网页交互的软件 什么是内核? --渲染引 ...
- python_大学排名爬取
逻辑思路是什么? 1. 获取页面 2. 处理页面,提取信息 3. 格式输出 先走面向过程编程: 1. 要定义3个函数,对应以上三个过程 2. 在__main__函数中传入参数,并执行以上三个过程 #! ...
- VUE脚手架搭建
1.什么vue-cli vue-cli是vue.js的脚手架,用于自动生成vue.js工程模板的. 步骤: 2.安装 ->全局安装 npm install vue-cli -g 或 ...
- Effective Java 之-----谨慎的覆盖clone方法
1.概述 如果clone方法返回一个由构造器创建的对象,它就得到有错误的类.因此,如果覆盖了非final类中的clone方法,则应该返回一个通过调用super.clone得到的对象.如果类的所有超类都 ...
- Effective Java 之 --- 用私有构造器或者枚举类型强化Singleton属性
Singleton指仅仅被实例化一次的类,通常用来代表那些本质上唯一的系统组件,实现Singleton有三种方法: 1)公有静态成员是个final域,享有特权的用户可以调用AccessibleObje ...
- 不使用Math.random实现随机数
不使用Math.random实现随机数 var rand = (function(){ var today = new Date(); var seed = today.getTime(); func ...
- XBIM 基于 WexBIM 文件在 WebGL 浏览和加载
目录 xBIM 应用与学习 (一) xBIM 应用与学习 (二) xBIM 基本的模型操作 xBIM 日志操作 XBIM 3D 墙壁案例 xBIM 格式之间转换 xBIM 使用Linq 来优化查询 x ...
- BZOJ 2005: [Noi2010]能量采集 [莫比乌斯反演]
题意:\((0,0)\)到\((x,y),\ x \le n, y \le m\)连线上的整点数\(*2-1\)的和 \((0,0)\)到\((a,b)\)的整点数就是\(gcd(a,b)\) 因为. ...
- Selenium_WebDriver_多窗口切换
摘要: 版权声明:本文为博主原创文章,转载请注明出处. 在页面操作过程中有时候点击某个链接会弹出新的窗口,这时我们如果需要操作新打开的页面,就需要将主机切换到新打开的窗口上再进行操作,比如博客园精华页 ...
- qt中的事件机制
事件 1.QEvent -->类型 -> QKeyEvent QEvent::KeyRelease QEvent::MouseMove -> QMouseEvent 2.事件处理过程 ...