HDU 5372 线段树
给出两种操作:
第i个0:在x位置插入一个长度为i的线段,并输出该线段共覆盖了多少之前增加的线段
1:删除第i次插入的线段
官方题解:对于新插入的线段,查询有多少个线段左端点大于等于该线段的左端点。 再查询有多少个线段的右端点大于该线段右端点, 两者之差就是答案。用两个树状数组搞定。时间复杂度nlog
思路非常好理解,直接用一个线段树记录区间的左端点和右端点就可以
#include "stdio.h"
#include "string.h"
#include "algorithm"
using namespace std;
const int inf=0x7fffffff;
struct A
{
int op,l,r,x;
} a[400010]; struct Y
{
int x,id;
} y[400010]; struct Data
{
int l,r,a,b;
} data[1600010]; bool cmp(Y a,Y b)
{
return a.x<b.x;
} void build(int l,int r,int k)
{
data[k].l=l;
data[k].r=r;
data[k].a=data[k].b=0;
if (l==r) return ; int mid=(l+r)/2; build(l,mid,k*2);
build(mid+1,r,k*2+1);
} int query(int l,int r,int k,int op)
{
if (l>r) return 0;
if (data[k].l==l && data[k].r==r)
{
if (op==1) return data[k].a;
else return data[k].b;
} int mid=(data[k].l+data[k].r)/2; if (r<=mid) return query(l,r,k*2,op);
else if (l>mid) return query(l,r,k*2+1,op);
else return query(l,mid,k*2,op)+query(mid+1,r,k*2+1,op);
} void updata(int n,int k,int op,int x)
{
if (op==1) data[k].a+=x;
else data[k].b+=x; if (data[k].l==n && data[k].r==n) return ; if (n<=data[k*2].r) updata(n,k*2,op,x);
else updata(n,k*2+1,op,x);
} int main()
{
int Case,n,i,x,cnt;
Case=1;
while (scanf("%d",&n)!=EOF)
{
cnt=1; for (i=0; i<n; i++)
{
scanf("%d",&a[i].op);
if (a[i].op==0)
{
scanf("%d",&a[i].l);
a[i].r=a[i].l+cnt;
cnt++;
}
else
{
scanf("%d",&x);
x--;
a[i].x=x;
}
y[i*2].x=a[i].l;
y[i*2].id=-i-1;
y[i*2+1].x=a[i].r;
y[i*2+1].id=i+1; }
sort(y,y+n*2,cmp);
cnt=0;
if (y[0].id<0)
a[-y[0].id-1].l=0;
else
a[y[0].id-1].r=0; for (i=1; i<n*2; i++)
{
if (y[i].x!=y[i-1].x) cnt++;
if (y[i].id<0) a[-y[i].id-1].l=cnt;
else a[y[i].id-1].r=cnt;
} build(0,cnt,1); printf("Case #%d:\n",Case++);
int temp=0;
for (i=0; i<n; i++)
{
if (a[i].op==0)
{
printf("%d\n",query(a[i].l,cnt,1,1)-query(a[i].r+1,cnt,1,2));
updata(a[i].l,1,1,1);
updata(a[i].r,1,2,1);
a[temp].l=a[i].l;
a[temp].r=a[i].r;
temp++;
}
else
{
updata(a[a[i].x].l,1,1,-1);
updata(a[a[i].x].r,1,2,-1);
} }
} return 0;
}
HDU 5372 线段树的更多相关文章
- hdu 5877 线段树(2016 ACM/ICPC Asia Regional Dalian Online)
Weak Pair Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- hdu 3974 线段树 将树弄到区间上
Assign the task Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- hdu 3436 线段树 一顿操作
Queue-jumpers Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) To ...
- hdu 3397 线段树双标记
Sequence operation Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- hdu 4578 线段树(标记处理)
Transformation Time Limit: 15000/8000 MS (Java/Others) Memory Limit: 65535/65536 K (Java/Others) ...
- hdu 4533 线段树(问题转化+)
威威猫系列故事——晒被子 Time Limit: 3000/1000 MS (Java/Others) Memory Limit: 65535/32768 K (Java/Others) Tot ...
- hdu 2871 线段树(各种操作)
Memory Control Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) T ...
- hdu 4052 线段树扫描线、奇特处理
Adding New Machine Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Othe ...
- hdu 1542 线段树扫描(面积)
Atlantis Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Su ...
随机推荐
- jsp&servlet报红线javax.servlet.jsp.XXXX cannot be resolved to a type类似错误解决办法
javax.servlet.jsp.JspException cannot be resolved to a type javax.servlet.jsp.PageContext cannot be ...
- 获取session中存储的所有值的方法
记录一个获取系统中session存储的对象都有哪些的方法 HttpSession session = request.getSession(); for ( Enumeration e = sessi ...
- 关于css的入门知识
css:叠层样式表,给html添加样式的 接下来说一说,在网页中如何嵌套style样式 1.行间样式:把style(*权重1000)作为属性卸载标签里 eg:<p style="col ...
- 03008_使用JDBC对分类表进行增删改查操作
1.创建数据库分类表 #创建数据库 create database mybase; #使用数据库 use dmybase; ###创建分类表 create table sort( sid int PR ...
- 【Codecraft-18 and Codeforces Round #458 (Div. 1 + Div. 2, combined) A】 Perfect Squares
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] N*1000暴力就好 [代码] #include <bits/stdc++.h> using namespace std ...
- cron 简单任务调度 go
package main import ( "github.com/robfig/cron" "log" ) func main() { i := 0 c := ...
- 洛谷 P1852 奇怪的字符串
P1852 奇怪的字符串 题目描述 输入两个01串,输出它们的最长公共子序列的长度 输入输出格式 输入格式: 一行,两个01串 输出格式: 最长公共子序列的长度 输入输出样例 输入样例#1: 复制 0 ...
- Vue框架学习笔记
<div id="app"> </div> var app = new Vue({ el:"#app", // 绑定的元素 data:{ ...
- 《WPF》Expander控件简单美化
示例图: Expander控件功能很常见, 一般用于系统左侧的菜单收缩面板. 1.主要的组成 一个头部(header) 和 一个 内容(content) 组成. <Expander Expand ...
- 洛谷 P1334 瑞瑞的木板
P1334 瑞瑞的木板 题目描述 瑞瑞想要亲自修复在他的一个小牧场周围的围栏.他测量栅栏并发现他需要N(1≤N≤20,000)根木板,每根的长度为整数Li(1≤Li≤50,000).于是,他神奇地买了 ...