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] ...
随机推荐
- Windows 端口占用
1.netstat -ano | findstr "80"( 80为提示被占用的端口): 2.tasklist | findstr "5584"(5584是从上 ...
- Python 数据类型:数值
数值类型分为:整型 .长整型 .浮点型 .复数型 整型示例: In [1]: a = 100 # 整型也就是整数类型 In [2]: type(a) # 整型的英文缩写为int Out[2]: int ...
- OpenGL 4.0 GLSL 基础教程概览——VAO和VBO常用操作接口
(一) OpenGL 4.3 最新渲染管线图 从OpenGL 2.0 到 OpenGL 3.0变化非常大,但从OpenGL 3.0 到OpenGL 4.0 变化不是太大. 着色器程序直接运行在GPU ...
- nginx服务器配置说明
总结nginx的一些配置选项: nginx全局配置文件 # 定义nginx运行的用户和组//一个默认同时为用户和组 //没有则默认为nobody user www-data; # nginx进程数,建 ...
- Java三方---->excel框架之POI的使用一
Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能.pdf框架之IText的使用,参见我的博客:Java ...
- VIM 插入
不知道有多少VIM新手和我当年(去年)一样,信誓旦旦的以为只有i可以插入 唉,现在想想都觉得可笑,都是Windows下的编辑器用多了的结果 鼠标一点,妈妈再也不用担心我的文本插入了……悲剧! 好了,让 ...
- 【Java nio】buffer
package com.slp.nio; import org.junit.Test; import java.nio.ByteBuffer; /** * Created by sanglp on 2 ...
- ACM中Java高效输入输出封装
来自互联网 : 既高效又好用才是王道! import java.io.IOException; import java.io.FileInputStream; import java.io.Input ...
- JavaIO详解
很全面的内容:http://www.cnblogs.com/rollenholt/archive/2011/09/11/2173787.html
- HTML的特殊字符-图标对应表
本文摘自:http://www.cnblogs.com/web-d/archive/2010/04/16/1713298.html HTML特殊字符编码大全:往网页中输入特殊字符,需在html代码 ...