hihocoder1711 评论框排版[并查集+set]
#include <cstdio>
#include <iostream>
#include <set>
using namespace std;
const int N = 1e5+; struct Block {
long long begin, all_size; //root起始, root子树总大小
long long dis, size, f; //距离父节点起始距离, 自身大小, 父节点标号
bool operator <(const Block &rhs) const {
return begin < rhs.begin;
}
};
Block block[N]; int findf(int x) {//找到标号x的根节点标号, 并让x直接连向根节点
if(x == block[x].f) return x;
int rt = findf(block[x].f);
int f = block[x].f;
block[x].dis += block[f].dis;
block[x].f = block[f].f;
return rt;
}
void merge(int x, int y) { //将标号y所在的子树merge到标号x所在的子树
int fx = findf(x), fy = findf(y);
if(fx == fy) return ;
block[fy].dis = block[fx].all_size;
block[fy].f = fx;
block[fx].all_size += block[fy].all_size;
} set<Block> se; int main() {
int n, k, h, x, tot = ;
char op;
scanf("%d", &n);
for(int i = ; i <= n; i++) {
scanf(" %c", &op);
if(op == 'I') {
scanf("%d%d", &k, &h);
int ID = ++tot;
block[tot] = {k, h, , h, tot};
if(se.empty()) {se.insert(block[ID]); continue ;} auto it = se.upper_bound(block[ID]);
if(it == se.begin()) {
while(it != se.end() && block[ID].begin+block[ID].all_size >= it->begin) {
int f = it->f;
se.erase(it++);
merge(ID, f);
}
se.insert(block[ID]);
}
else { // it != se.begin()
auto tmp = it;
--tmp;
if(tmp->begin + tmp->all_size >= k) {
int f = tmp->f;
se.erase(tmp);
merge(f, tot);
ID = f;//////////////////////////////////////////
}
while(it != se.end() && block[ID].begin+block[ID].all_size >= it->begin) {
int f = it->f;
se.erase(it++);
merge(ID, f);
}
se.insert(block[ID]);
}
}
else {
scanf("%d", &x);
int rt = findf(x);
long long L = block[x].dis+block[rt].begin;
long long R = L+block[x].size-;
printf("%I64d %I64d\n", L, R);
}
}
return ;
} /*
5
I 1 5
I 8 10
I 5 5
Q 3
Q 2
*/
hihocoder1711 评论框排版[并查集+set]的更多相关文章
- HDU 1272 小希的迷宫(并查集) 分类: 并查集 2015-07-07 23:38 2人阅读 评论(0) 收藏
Description 上次Gardon的迷宫城堡小希玩了很久(见Problem B),现在她也想设计一个迷宫让Gardon来走.但是她设计迷宫的思路不一样,首先她认为所有的通道都应该是双向连通的,就 ...
- Hdu 2473(并查集删除操作) Junk-Mail Filter
有木有非常吊 加强 加强版 啊 ,看了都不敢做了 .后来先做了食物链这个我还是看过的.但还是A不掉,没明确神魔意思 .总而言之.大牛的博客是个好东西.我就那么看了一下,还是不懂怎莫办啊,哎, ...
- <hdu - 1272> 小希的迷宫 并查集问题 (注意特殊情况)
本题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1272 Problem Description: 上次Gardon的迷宫城堡小希玩了很久(见Probl ...
- <hdu - 1232> 畅通工程 并查集问题 (注意中的细节)
本题链接:http://acm.hdu.edu.cn/showproblem.php?pid=1232 结题思路:因为题目是汉语的,那我就不解释题意了,要求的是最少建设的道路,我们可以用并查集来做这 ...
- 并查集+bfs+暴力滑窗 Codeforces Round #356 (Div. 2) E
http://codeforces.com/contest/680/problem/E 题目大意:给你一个n*n的图,然后图上的 . (我们下面都叫做‘点’)表示可以走,X表示不能走,你有如下的操作, ...
- Tarjan 模板,高级并查集
第一个模板有误!!!! 请见谅!!! 要怪就怪HDU吧,竟然让我过了 第二个模板是正确的.请翻到下面看更新 HDU 1269 评论区居然有人说用并查集过了,其实回想一下 求无向图的连通分量,就是并查集 ...
- 搭桥|codevs1002|最小生成树|Prim|并查集|Elena
1002 搭桥 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 有一矩形区域的城市中建筑了若干建筑物,如果某两个单元格有一个点 ...
- 【洛谷】P1892 团伙(并查集)+ 求助
题目描述 1920年的芝加哥,出现了一群强盗.如果两个强盗遇上了,那么他们要么是朋友,要么是敌人.而且有一点是肯定的,就是: 我朋友的朋友是我的朋友: 我敌人的敌人也是我的朋友. 两个强盗是同一团伙的 ...
- Luogu P2391 白雪皑皑 && BZOJ 2054: 疯狂的馒头 并查集
4月的时候在luogu上做过 白雪皑皑 这道题,当时一遍AC可高兴了qwq,后来去了个厕所,路上忽然发现自己的做法是错的qwq...然后就咕咕了qwq 今天看到了 疯狂的馒头 ,发现一毛一样OvO.. ...
随机推荐
- Jmeter+Ant+Jenkins持续集成方案改进
关于Jmeter+Ant+Jenkins如何搭建持续集成环境,网上资料一大把,就不多说了,本文主要谈一下期间的问题及扩展该持续集成方案. 其实核心的流程不复杂,Jenkins管理构建项目,Ant配置脚 ...
- Java类型转换工具类(十六进制—bytes互转、十进制—十六进制互转,String—Double互转)
/** * 数据类型转换工具类 * @author cyf * */ public class NumConvertUtil{ /** * bytes 转16进制字符串 * @param bArray ...
- 最安全的聊天工具——Cryptocat
关于Cryptocat Cryptocat 是啥?Cryptocat,俗称 "加密猫",是一款非常注重安全的聊天软件. 美国前中情局员工斯诺登在躲避美国政府追捕过程中,就是使用 C ...
- hdfs命令大全
hdfs常用命令: 第一部分:hdfs文件系统命令 第一类:文件路径增删改查系列: hdfs dfs -mkdir dir 创建文件夹 hdfs dfs -rmr dir 删除文件夹dir hdf ...
- vue 使用ref获取DOM元素和组件引用
在vue中可以通过ref获取dom元素,并操作它,还可以获取组件里面的数据和方法. HTML部分: <div id="app"> <input type=&quo ...
- Netty源码分析第2章(NioEventLoop)---->第2节: NioEventLoopGroup之NioEventLoop的创建
Netty源码分析第二章: NioEventLoop 第二节: NioEventLoopGroup之NioEventLoop的创建 回到上一小节的MultithreadEventExecutorG ...
- redis使用Jackson2JsonRedisSerializer序列化问题
一.spring boot 集成Redis方法 依赖 <!--redis--> <dependency> <groupId>org.springframework. ...
- Laravel路由除了根目录全报404错误
Route::get('hello',function(){ return 'Hello World!'; }); 在laravel/app/Http/routes.php下添加上面的语句,然后再浏览 ...
- Visual Studio AI 离线模型训练(window 7)
本篇博客用tensorflow训练自带的数据mnist,参考自博客. 背景: 搭建好AI环境:查看 window 7 64位 准备工作: 在搭建AI环境过程中下载的samples-for-ai不是最新 ...
- java中的装箱与拆箱
什么是自动装箱拆箱 基本数据类型的自动装箱(autoboxing).拆箱(unboxing)是自J2SE 5.0开始提供的功能. 一般我们要创建一个类的对象实例的时候,我们会这样: Class a = ...