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 ...
随机推荐
- You have ettempted to queue to many files.You may select one files.
<script type="text/javascript" src="/script/swfupload/swfupload.js"></s ...
- js---04 属性 this
var oUl = document.getElementsByTagName('ul')[0]; var aLi = oUl.getElementsByTagName('li'); window.o ...
- Fragment-管理Fragment1
前面给大家稍微看了要怎么使用fragment,在上篇中,我们也初步接触到了add,replace这些fragment操作的函数,下面就再详细讲讲如何管理Fragment页面吧. 一.概述 1.Frag ...
- Kinect 开发 —— 硬件设备解剖
Kinect for Xbox: 360 不支持“近景模式” 三只眼睛 —— 红外投影机,RGB摄像头,红外深度投影头 —— 色彩影像中的每个像素分别与深度影像中的一个像素对应 四只耳朵 —— L形 ...
- 【Django】缓存
由于Django是动态网站,所以每次请求都会去数据库中进行响应的操作. 当程序访问量大时,耗时必然会更加明显,最简单的解决方案就是使用缓存. Django中的缓存: ==即将某一个view的返回值保存 ...
- 免费超大量邮件发送服务Amazon SES和Mailgun提供SMTP和API支持
一般来说网站注册.论坛消息.新闻推送.广告宣传等都会有发送邮件服务,大量的邮件发送服务如果用PHP来发送,一是会消耗主机资源,二是容易被各大邮箱判定为垃圾邮件而被拒收.用第三方的邮局服务发送邮件,可以 ...
- sql跳过非工作日(周末和节假日)
简介:场景1:基于开始日期和工期,推算结束日期. 场景2:基于开始日期和结束日期,计算工期 注:需要自己做界面维护工作日表(s_WorkDay)和节假日表(s_SpecialDay) 涉及到的数据表 ...
- jQ-多选按钮实现单选按钮的功能以及input按钮的优化
css: .displayN{display: none;} label {font-size:12px;cursor:pointer;} label i {font-size:12px;font-s ...
- domino web app
近期在做个项目内容是:原企业的OA仅仅能在电脑桌面处理流程,不能在手机上处理审核功能,但随着企业需求,管理者需求在随时使用手机审核文档,达到及时处理文档及流程的及时性. 要求:1) ...
- animation- 动画效果实现(代码中)
1,首先我们看一下如下的代码 import android.view.animation.LayoutAnimationController; import android.view.animatio ...