hdu1199 线段树
这题说的是给了 n 个操作。 每个操作会把 【a,b】 之间的球 涂为黑色或者 白色, 然后最后问 最长的连续的白色的 球有多少个,初始的时候全是黑的。
我们将所有的点离散化, 记得离散 a-1, b+1, 因为如果你不离散 a-1 那么 在区间间隔时 间隔是黑色的 没有操作的你会计算成白色的, 然后如果不加b+1 会使得同起点的区间白色的部分会被后来比他小的黑色区间覆盖, 导致最后 白色的少了
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <string.h>
using namespace std;
typedef long long ll;
const int maxn = ;
ll X[maxn],Y[maxn];
int op[maxn];
ll Loc[maxn*];
int cL, cR ,V,tim;
ll ansL,ansR,preL,preR;
struct Itree{
int color[maxn*];
void build(int o, int L, int R){
color[o]=;
}
void pushdown(int o){
color[o*]=color[o];
color[o*+]=color[o];
color[o]=-;
}
void update(int o, int L , int R){
if(cL<=L && R<=cR ){
color[o]=V; return;
}
int mid=(L+R)/;
if(color[o]!=-) pushdown(o);
if(cL<=mid) update(o*, L, mid);
if(cR>mid) update(o*+, mid+, R);
}
void endop(int o, int L, int R){
if(color[o]!=-){
if(color[o]==){
if(tim==){
tim=; preL=Loc[L-]; preR=Loc[R-];
if(preR-preL>ansR-ansL){
ansL=preL; ansR=preR;
}
}else{
preR=Loc[R-];
if(preR-preL>ansR-ansL){
ansL=preL; ansR=preR;
}
}
}else
tim=;
return ;
}
if(L==R) return ;
int mid=(L+R)/;
endop(o*,L, mid);
endop(o*+, mid+,R);
}
}T;
int main()
{
int n;
char st[];
while(scanf("%d",&n)==){
int ge=;
for(int i=; i<n; ++i ){
scanf("%I64d%I64d%s",&X[i],&Y[i],st);
/* ll a = X[i] ,b =Y[i];
X[i]=min(a,b);
Y[i]=max(a,b);*/
if(st[]=='b') op[i]=;
else op[i]=;
Loc[ge++]=X[i]; Loc[ge++]=Y[i];
Loc[ge++]=X[i]-; Loc[ge++]=Y[i]+;
}
sort(Loc,Loc+ge);
ge = unique(Loc,Loc+ge)-Loc;
T.build(,,ge);
for(int i=; i<n; ++i){
cL =lower_bound(Loc,Loc+ge,X[i])-Loc+;
cR =lower_bound(Loc, Loc+ge, Y[i])-Loc+;
V=op[i];
T.update(,,ge);
}
ansL=; ansR=-;tim=;
T.endop(,,ge);
if(ansL>ansR){
puts("Oh, my god");
}else{
printf("%I64d %I64d\n",ansL, ansR);
}
}
return ;
}
hdu1199 线段树的更多相关文章
- HDU1199 动态线段树 // 离散化
附动态线段树AC代码 http://acm.hdu.edu.cn/showproblem.php?pid=1199 因为昨天做了一道动态线段树的缘故,今天遇到了这题没有限制范围的题就自然而然想到了动态 ...
- bzoj3932--可持久化线段树
题目大意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第 ...
- codevs 1082 线段树练习 3(区间维护)
codevs 1082 线段树练习 3 时间限制: 3 s 空间限制: 128000 KB 题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...
- codevs 1576 最长上升子序列的线段树优化
题目:codevs 1576 最长严格上升子序列 链接:http://codevs.cn/problem/1576/ 优化的地方是 1到i-1 中最大的 f[j]值,并且A[j]<A[i] .根 ...
- codevs 1080 线段树点修改
先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...
- codevs 1082 线段树区间求和
codevs 1082 线段树练习3 链接:http://codevs.cn/problem/1082/ sumv是维护求和的线段树,addv是标记这歌节点所在区间还需要加上的值. 我的线段树写法在运 ...
- PYOJ 44. 【HNSDFZ2016 #6】可持久化线段树
#44. [HNSDFZ2016 #6]可持久化线段树 统计 描述 提交 自定义测试 题目描述 现有一序列 AA.您需要写一棵可持久化线段树,以实现如下操作: A v p x:对于版本v的序列,给 A ...
- CF719E(线段树+矩阵快速幂)
题意:给你一个数列a,a[i]表示斐波那契数列的下标为a[i],求区间对应斐波那契数列数字的和,还要求能够维护对区间内所有下标加d的操作 分析:线段树 线段树的每个节点表示(f[i],f[i-1])这 ...
- 【BZOJ-3779】重组病毒 LinkCutTree + 线段树 + DFS序
3779: 重组病毒 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 224 Solved: 95[Submit][Status][Discuss] ...
随机推荐
- Python 循环退出
常用语句: break :退出整个循环,循环外的语句继续执行continue :退出本次循环,继续下一次循环pass :什么也不做,相当于在这里占个位置,以便以后修改代码sys.exit() :直接退 ...
- Unity鼠标点击Collider
void OnGUI() { if (Event.current != null && Event.current.type == EventType.mouseDown) { )) ...
- mac 类似Xshell
ssh -t root@12.23.34.45 -p 22 ssh -t 用户名@IP地址 -p 端口
- css纯字母或者字母换行显示
white-space:normal; word-break:break-all;
- js如何判断不同的操作系统
<html> <head> <title>判断操作系统</title> <script type="text/javascript&qu ...
- MUI 单个图片上传预览(拍照+系统相册):先选择->预览->上传提交
1 html部分 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> < ...
- android基础---->发送和接收短信
收发短信应该是每个手机最基本的功能之一了,即使是许多年前的老手机也都会具备这项功能,而Android 作为出色的智能手机操作系统,自然也少不了在这方面的支持.今天我们开始自己创建一个简单的发送和接收短 ...
- bootstrap之
一.字体图标 <button type="button" class="btn btn-primary btn-lg"> <span clas ...
- net 中的一些知识
这是一篇摘抄的文章 有一些内容对我很有帮助 .有一些内容解释很清晰 所以我拿过来了. 第一遍用了5天时间,第二遍看的时候决定自己复制一份出来于是有了这儿博客. 什么是.NET?什么是.NET Fram ...
- 树链剖分+离散+扫描(HDU5044)
Tree Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total Subm ...