UVALive 4730 Kingdom +段树和支票托收
主题链接:点击打开链接
题意见白书P248
思路:
先把读入的y值都扩大2倍变成整数
然后离散化一下
用线段树来维护y轴 区间上每一个点的 城市数量和联通块数量。
然后用并查集维护每一个联通块及联通块的最大最小y值。还要加并查集的秩来记录每一个联通块的点数
然后就是模拟搞。
。
T^T绝杀失败题。。似乎数组开小了一点就过了。==
#include<stdio.h>
#include<math.h>
#include<vector>
#include<string.h>
#include<algorithm>
using namespace std;
#define rank Rank
#define L(x) (x<<1)
#define R(x) (x<<1|1)
#define Lson(x) tree[x].l
#define Rson(x) tree[x].r
#define Sum0(x) tree[x].sum[0]
#define Lazy0(x) tree[x].lazy[0]
#define Sum1(x) tree[x].sum[1]
#define Lazy1(x) tree[x].lazy[1]
inline int Mid(int x, int y){return (x+y)>>1;}
#define N 100005
struct Point{
int x, y;
}p[100005];
struct que{
int u, v, op;
}Q[200005];
vector<int>G;
int n, q;
char s[10]; struct node{
int l, r, sum[2], lazy[2];
}tree[N<<4];
void push_down(int id){
if(Lazy1(id)) {
Sum1(L(id)) += Lazy1(id);
Sum1(R(id)) += Lazy1(id);
Lazy1(L(id)) += Lazy1(id);
Lazy1(R(id)) += Lazy1(id);
Lazy1(id) = 0;
}
if(Lazy0(id)) {
Sum0(L(id)) += Lazy0(id);
Sum0(R(id)) += Lazy0(id);
Lazy0(L(id)) += Lazy0(id);
Lazy0(R(id)) += Lazy0(id);
Lazy0(id) = 0;
}
}
void push_up(int id){Sum0(id) = Sum0(L(id)) + Sum0(R(id));Sum1(id) = Sum1(L(id)) + Sum1(R(id));}
void build(int l, int r, int id){
Lson(id) = l; Rson(id) = r;
Sum0(id) = Lazy0(id) = Sum1(id) = Lazy1(id) = 0;
if(l == r) return ;
int mid = Mid(l, r);
build(l, mid, L(id));
build(mid+1, r, R(id));
}
void updata(int l, int r, int val, int now, int id){
push_down(id);
if(l == Lson(id) && Rson(id) == r) {
if(now==0)Sum0(id) += val, Lazy0(id) += val;
else Sum1(id) += val, Lazy1(id) += val;
return ;
}
int mid = Mid(Lson(id), Rson(id));
if(mid < l)
updata(l, r, val, now, R(id));
else if(r <= mid)
updata(l, r, val, now, L(id));
else {
updata(l, mid, val, now, L(id));
updata(mid+1, r, val, now, R(id));
}
push_up(id);
}
int query(int pos, int now, int id){
push_down(id);
if(Lson(id)==Rson(id))if(now==0)return Sum0(id); else return Sum1(id);
int mid = Mid(Lson(id), Rson(id));
int ans;
if(mid < pos)
return query(pos, now, R(id));
else return query(pos, now, L(id));
}
int f[100005], rank[100005], S[100005], X[100005]; //每一个集合的上下界
int find(int x){return x==f[x]?x:f[x] = find(f[x]);}
void Union(int x, int y){
int fx = find(x), fy = find(y);
if(fx == fy)return;
if(S[fx] > S[fy]) swap(fx, fy);
if(S[fx] <= X[fy]){
updata(S[fx], X[fy], 1, 0, 1);
updata(S[fx], X[fy], rank[fx] + rank[fy], 1, 1);
updata(X[fx], S[fx], rank[fy], 1, 1);
updata(X[fy], S[fy], rank[fx], 1, 1);
}
else if(X[fx] >= X[fy]) {
updata(X[fx], S[fx], -1, 0, 1);
updata(X[fy], X[fx], rank[fx], 1, 1);
updata(S[fx], S[fy], rank[fx], 1, 1);
}
else {
updata(X[fy], S[fx], -1, 0, 1);
updata(X[fx], X[fy], rank[fy], 1, 1);
updata(S[fx], S[fy], rank[fx], 1, 1);
}
if(rank[fy]<rank[fx])swap(fx, fy);
f[fx] = fy;
rank[fy] += rank[fx];
rank[fx] = 0;
X[fy] = min(X[fy], X[fx]);
S[fy] = max(S[fy], S[fx]);
} void input(){
G.clear();
scanf("%d", &n);
for(int i = 1; i <= n; i++) f[i] = i, rank[i] = 1;
for(int i = 1; i <= n; i++) scanf("%d %d",&p[i].x, &p[i].y), p[i].y <<= 1, G.push_back(p[i].y);
scanf("%d", &q);
for(int i = 0; i < q; i++)
{
scanf("%s", s);
if(s[0]=='r')
{
Q[i].op = 1;
scanf("%d %d", &Q[i].u, &Q[i].v); Q[i].u++; Q[i].v++;
}
else {
Q[i].op = 2;
scanf("%d.5",&Q[i].u);
Q[i].u = Q[i].u * 2+1;
G.push_back(Q[i].u);
}
}
sort(G.begin(), G.end());
G.erase(unique(G.begin(), G.end()), G.end());
for(int i = 1; i <= n; i++)X[i] = S[i] = p[i].y = lower_bound(G.begin(), G.end(), p[i].y) - G.begin()+1;
for(int i = 0; i < q; i++)if(Q[i].op == 2)Q[i].u = lower_bound(G.begin(), G.end(), Q[i].u) - G.begin()+1;
}
int main() {
int T; scanf("%d",&T);
while(T--){
input();
build(1, G.size(), 1);
for(int i = 0; i < q; i++) {
if(Q[i].op == 1)
{
Union(Q[i].u, Q[i].v);
}
else
printf("%d %d\n", query(Q[i].u, 0, 1), query(Q[i].u, 1, 1));
}
}
return 0;
}
/*
3
11
1 7
5 7
8 6
3 5
5 5
2 3
10 3
7 2
4 1
11 1
4 6
21
road 0 1
road 3 5
line 6.5
road 4 2
road 3 8
road 4 7
road 6 9
road 4 1
road 2 7
line 4.5
line 6.5
line 3.5
line 2.5
line 5.5
road 10 0
line 5.5
line 6.5
road 0 3
line 1.5
line 6.5
line 2.5 ans:
0 0
2 8
1 5
2 8
3 10
1 5
1 6
1 6
2 11
1 9
2 11 */
版权声明:本文博客原创文章,博客,未经同意,不得转载。
UVALive 4730 Kingdom +段树和支票托收的更多相关文章
- BZOJ-3212 Pku3468 A Simple Problem with Integers 裸线段树区间维护查询
3212: Pku3468 A Simple Problem with Integers Time Limit: 1 Sec Memory Limit: 128 MB Submit: 1278 Sol ...
- ZOJ 1610 间隔染色段树
要长8000仪表板.间染色的范围,问:最后,能看到的颜色,而且颜色一共有段出现 覆盖段 数据对比水 水可太暴力 段树: #include "stdio.h" #include ...
- HDU 1394 Minimum Inversion Number (数据结构-段树)
Minimum Inversion Number Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java ...
- PKU A Simple Problem with Integers (段树更新间隔总和)
意甲冠军:一个典型的段树C,Q问题,有n的数量a[i] (1~n),C, a, b,c在[a,b]加c Q a b 求[a,b]的和. #include<cstdio> #include& ...
- BZOJ 2588 Count on a tree (COT) 是持久的段树
标题效果:两棵树之间的首次查询k大点的权利. 思维:树木覆盖树,事实上,它是正常的树木覆盖了持久段树. 由于使用权值段树可以寻求区间k大,然后应用到持久段树思想,间隔可以做减法.详见代码. CODE: ...
- lintcode-439-线段树的构造 II
439-线段树的构造 II 线段树是一棵二叉树,他的每个节点包含了两个额外的属性start和end用于表示该节点所代表的区间.start和end都是整数,并按照如下的方式赋值: 根节点的 start ...
- lintocde-247-线段树的查询 II
247-线段树的查询 II 对于一个数组,我们可以对其建立一棵 线段树, 每个结点存储一个额外的值 count 来代表这个结点所指代的数组区间内的元素个数. (数组中并不一定每个位置上都有元素) 实现 ...
- lintcode-203-线段树的修改
203-线段树的修改 对于一棵 最大线段树, 每个节点包含一个额外的 max 属性,用于存储该节点所代表区间的最大值. 设计一个 modify 的方法,接受三个参数 root. index 和 val ...
- lintcode-202-线段树的查询
202-线段树的查询 对于一个有n个数的整数数组,在对应的线段树中, 根节点所代表的区间为0-n-1, 每个节点有一个额外的属性max,值为该节点所代表的数组区间start到end内的最大值. 为Se ...
随机推荐
- SQL Tuning Advisor一个错误ORA-00600: internal error code, arguments: [kesqsMakeBindValue:obj]
跑SELECT dbms_sqltune.report_tuning_task(:tuning_task) FROM dual; 错误消息,如下面: ORA-00600: internal erro ...
- 中文/英文双语言版本TWRP for Nexus5 -hammerheadcaf
编译及作者:laser杨万荣 编译时间: 2015-05-17 编译目的:用于刷cm-12.0 和cm-12.1 ROM 因为现在Nexus5 最新的 CM是 hammerheadcaf ,即和 ao ...
- 绕过电信访问Google
最近google被“DNS污染系统”攻击,导致域名无法正常跳转到解析IP,google业务无法访问,也无法使用google搜索,DNS域名污染系统攻击造成google本身故障的假象,针对此问题,一般都 ...
- java 注解 学习
周末闲来无事,想要研究一下注解方面的知识,曾经看过几次,都忘记了,这次学习下,而且写篇文章记录下, 1.元注解 元注解是指注解的注解.包含 @Retention @Target @Document ...
- 从一开始,说出事java匿名内部类
java内部类.匿名类原本以为它们的使用已经很滑, 成绩, 就在昨天晚上12指向时钟发生重大事故.事故的严重程度再说吧,那是因为我没有睡一晚睡眠. 那以下先用一段模拟代码来描写叙述下我出现的问题的: ...
- 正确使用Git Flow
Git 在团队中的最佳实践--如何正确使用Git Flow 我们已经从SVN 切换到Git很多年了,现在几乎所有的项目都在使用Github管理, 本篇文章讲一下为什么使用Git, 以及如何在团队中正确 ...
- Android Application Thread CPU GC Operatiing and OOM Question 0603-随手笔记
面前app当完成测试,没问题,以完成整个老龄化阶段包含数据收发器,关键在 adb shell top -m 5 我发现我的 app pid 占用 CPU是最多的,事实上我想说写一个app是不难,你 ...
- 基于struct2完整的用户登录
第一lib在导入struct2相应jar包 在web.xml组态struct2过滤器 <filter> <filter-name>struts2</filter-name ...
- UVALive 5103 Computer Virus on Planet Pandora Description 一些新兴需求模式的字符串 AC自己主动机
主题链接:option=com_onlinejudge&Itemid=8&page=show_problem&problem=3104">点击打开链接 题意: ...
- android 常见的解决(mdpi、hdpi 、xhdpi、xxhdpi )屏幕调整
查询到执行的system service后,就能够在dumpsys后面加上service的名字,查看指定的service信息. adb shell dumpsys activity adb shell ...