意甲冠军:给你1-n花瓶   。起初,所有的空,今天,有两种操作模式,

1:从花瓶a開始插入b朵花          假设不能插进去  输出字符串  否则输出最多插入的起点和终点;

2:把a-b的花瓶清空   输出处理花的个数;

结构体数组num【i】表示节点i空瓶的数目

线段树   開始deal函数对整个树初始化,update()更新函数 find()查询区间有多少个空瓶;     对于操作1    关键点是找到起点和终点   这里用二分  在【a,n】进行二分,

先二分起点       注意左右区间的变换(wa了好多次==)   然后在起点和n之间二分终点   最后更新  输出     对于操作2     直接查询就可以;

#include<stdio.h>
#include<string.h>
#include<iostream>
using namespace std; #define LL(x) (x<<1)
#define RR(x) ((x<<1)|1)

struct
node
{
int
cont;
}
num[50000*4];
int
deal(int L,int R,int point)
{

num[point].cont=R-L+1;
if(
L==R) return 0;
int
mid=(L+R)/2;
deal(L,mid,LL(point));
deal(mid+1,R,RR(point));
return
0;
}
int
update(int L,int R,int left,int right,int point,int k)
{
if(
L==left&&R==right)
{
if(
k==1) num[point].cont=R-L+1;
else
num[point].cont=0;
return
0;
}
int
mid=(L+R)/2;
if(
num[point].cont==R-L+1)
{

num[LL(point)].cont=mid-L+1;
num[RR(point)].cont=R-mid;
}
if(
num[point].cont==0)
{

num[LL(point)].cont=0;
num[RR(point)].cont=0;
}
if(
right<=mid)
{

update(L,mid,left,right,LL(point),k);
}
else if(
left>mid)
{

update(mid+1,R,left,right,RR(point),k);
}
else
{

update(L,mid,left,mid,LL(point),k);
update(mid+1,R,mid+1,right,RR(point),k);
}

num[point].cont=num[LL(point)].cont+num[RR(point)].cont;
return
0;
}
int
find(int L,int R,int left,int right,int point)
{
if(
L==left&&R==right)
return
num[point].cont;
int
sum=0;
int
mid=(L+R)/2;
if(
num[point].cont==R-L+1) return right-left+1;
if(
num[point].cont==0) return 0;
if(
right<=mid) sum+=find(L,mid,left,right,LL(point));
else if(
left>mid) sum+=find(mid+1,R,left,right,RR(point));
else
{

sum+=find(L,mid,left,mid,LL(point));
sum+=find(mid+1,R,mid+1,right,RR(point));
}
return
sum;
}
int main()
{
int
n,m,k,i,j,T,a,b;
scanf("%d",&T);
while(
T--)
{

scanf("%d%d",&n,&m);
deal(1,n,1);
for(
i=1;i<=m;i++)
{

scanf("%d%d%d",&k,&a,&b);
if(
k==1)
{

a+=1;
int
cont=find(1,n,a,n,1);
if(
cont==0) printf("Can not put any one.\n");
else
{
int
left,right,mid;
int
star,end;
left=a;
right=n;
while(
left<=right)
{

mid=(left+right)/2;
if(
find(1,n,left,mid,1)>0)
{

right=mid-1;
star=mid;
}
else
left=mid+1; }
if(
cont<=b)
{

left=a;
right=n;
while(
left<=right)
{

mid=(left+right)/2;
if(
find(1,n,mid,right,1)>0)
{

left=mid+1;
end=mid;
}
else
right=mid-1;
}

//end=right;
}
else
{

left=a;
right=n;
while(
left<=right)
{

mid=(left+right)/2;
if(
find(1,n,star,mid,1)>=b)
{

right=mid-1;
end=mid;
}
else
left=mid+1;
}

//end=left;
}
printf("%d %d\n",star-1,end-1);
update(1,n,star,end,1,-1);
}
}
else
{

printf("%d\n",b-a+1-find(1,n,a+1,b+1,1));
update(1,n,a+1,b+1,1,1);
} }

printf("\n");
}
return
0;
}

hdu4614 二分法+段树的更多相关文章

  1. BZOJ-3212 Pku3468 A Simple Problem with Integers 裸线段树区间维护查询

    3212: Pku3468 A Simple Problem with Integers Time Limit: 1 Sec Memory Limit: 128 MB Submit: 1278 Sol ...

  2. ZOJ 1610 间隔染色段树

    要长8000仪表板.间染色的范围,问:最后,能看到的颜色,而且颜色一共有段出现 覆盖段 数据对比水   水可太暴力 段树: #include "stdio.h" #include ...

  3. HDU 1394 Minimum Inversion Number (数据结构-段树)

    Minimum Inversion Number Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java ...

  4. PKU A Simple Problem with Integers (段树更新间隔总和)

    意甲冠军:一个典型的段树C,Q问题,有n的数量a[i] (1~n),C, a, b,c在[a,b]加c Q a b 求[a,b]的和. #include<cstdio> #include& ...

  5. BZOJ 2588 Count on a tree (COT) 是持久的段树

    标题效果:两棵树之间的首次查询k大点的权利. 思维:树木覆盖树,事实上,它是正常的树木覆盖了持久段树. 由于使用权值段树可以寻求区间k大,然后应用到持久段树思想,间隔可以做减法.详见代码. CODE: ...

  6. lintcode-439-线段树的构造 II

    439-线段树的构造 II 线段树是一棵二叉树,他的每个节点包含了两个额外的属性start和end用于表示该节点所代表的区间.start和end都是整数,并按照如下的方式赋值: 根节点的 start ...

  7. lintocde-247-线段树的查询 II

    247-线段树的查询 II 对于一个数组,我们可以对其建立一棵 线段树, 每个结点存储一个额外的值 count 来代表这个结点所指代的数组区间内的元素个数. (数组中并不一定每个位置上都有元素) 实现 ...

  8. lintcode-203-线段树的修改

    203-线段树的修改 对于一棵 最大线段树, 每个节点包含一个额外的 max 属性,用于存储该节点所代表区间的最大值. 设计一个 modify 的方法,接受三个参数 root. index 和 val ...

  9. lintcode-202-线段树的查询

    202-线段树的查询 对于一个有n个数的整数数组,在对应的线段树中, 根节点所代表的区间为0-n-1, 每个节点有一个额外的属性max,值为该节点所代表的数组区间start到end内的最大值. 为Se ...

随机推荐

  1. stm32的pwm波

  2. NET使用ABP框架搭建项目

    NET使用ABP框架搭建博客项目(一) 有很多学NET开发的小伙伴建项目都比较茫然,我用什么开发?我都使用什么框架?我怎么起名字?种种问题,让一些低等.中等的工程师(甚至是高级工程师)很烦躁. 推荐一 ...

  3. solr源码导入eclipse 分类: H4_SOLR/LUCENCE 2014-07-14 14:11 550人阅读 评论(1) 收藏

    转载自:http://blog.csdn.net/vltic/article/details/19917377 (1)相应的开发环境准备          (1)jdk1.6+的安装和环境变量配置(命 ...

  4. jdbc之二:DAO模式 分类: B1_JAVA 2014-04-29 15:13 1536人阅读 评论(0) 收藏

    详细代码请参见 https://github.com/lujinhong/dao 一.前期准备 1.创建数据库 create database filter_conf; 2.创建表并插入数据 crea ...

  5. js课程 1-4 js变量的作用域是怎样的

    js课程  1-4   js变量的作用域是怎样的 一.总结 一句话总结:只有在函数内部前面带var的变量为局部变量,局部变量只能在函数体内使用. 1.什么情况下会出现NaN类型的错误,举一例? Num ...

  6. Android菜鸟的成长笔记(27)——SurfaceView的使用

    前面有关自定义View中进行了绘图,但View的绘图机制存在如下缺陷: 1.View缺乏双缓冲机制. 2.当程序需要更新View上的图像时,程序必须重绘View上显示的整张图片. 3.新线程无法直接更 ...

  7. 【转】Boost.Python

    http://edyfox.codecarver.org/html/boost_python.html Boost.Python 是 Boost 中的一个组件,使用它能够大大简化用 C++ 为 Pyt ...

  8. [.NET Core 24]把project.json迁移到.csproj

    链接:https://blog.jetbrains.com/dotnet/2017/04/04/rider-eap-update-csproj-based-net-core-support-migra ...

  9. SpringMVC拦截器-路径语法-略坑

    项目中遇到一种场景,登录拦截器需要拦截.html后缀等动态请求,但是发现语法不对头.    <mvc:interceptors>      <mvc:interceptor> ...

  10. 5.Maven和Eclipse整合(两种方式进行插件的安装),Maven相关设置,Eclipse下创建Maven项目

     1  第一种方式是:在连网的情况下.通过在helpàInstall下安装. 新的地址是:http://download.eclipse.org/technology/m2e/releases 2 ...