Acdream1157---Segments (CDQ分治)
陈丹琦分治~~~其实一些数据小的时候可以用二维或者多维树状数组做的,而数据大的时候就无力的题目,都可以用陈丹琦分治解决。
题目:由3钟类型操作:
1)D L R(1 <= L <= R <= 1000000000) 增加一条线段[L,R]
2)C i (1-base) 删除第i条增加的线段,保证每条插入线段最多插入一次,且这次删除操作一定合法
3) Q L R(1 <= L <= R <= 1000000000) 查询目前存在的线段中有多少条线段完全包含[L,R]这个线段,线段X被线段Y完全包含即LY <= LX
<= RX <= RY)
给出N,接下来N行,每行是3种类型之一
由于 L R 比较大,直接是不行的,于是我们可以利用CDQ分治把二维变成一维,然后离散化。树状数组查询。
对于询问 L R 只需要 知道 小于等于L 且大于等于R的有多少个就可以了。这里我是把线段左端点进行CDQ分治,然后每次查询大于R数目。
#include <cstdio>
#include <string>
#include <vector>
#include <cstdlib>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;
const int maxn = 1e5+;
struct Node
{
int idx,l,r,delt;
int kind;
bool operator < (const Node &rhs)const
{
return l < rhs.l ;
}
}node[maxn];
int ans[maxn],del[maxn];
//-------------BIT--------- //此处树状数组反向写的,用于查询 大于等于x的数有多少个
inline int lowbit (int x)
{
return x & -x;
}
int arr[maxn],MAX;
void add (int x,int d)
{
while (x)
{
arr[x] += d;
x -= lowbit(x);
}
}
int sum(int x)
{
int ans = ;
while (x <= MAX)
{
ans += arr[x];
x += lowbit(x);
}
return ans;
}
//--------------离散化-----
int vec[maxn],vec_idx;
int hash_(int x)
{
return lower_bound(vec,vec+vec_idx,x) - vec + ;
}
//------------------------
void CDQ(int l,int r)
{
if (l == r)
return;
int mid = (l + r) >> ;
CDQ(l,mid);
CDQ(mid+,r);
int j = l;
for (int i = mid+; i <= r; i++)
{
if (node[i].kind == )
{
for ( ;j <= mid && node[j].l <= node[i].l; j++)
{
if (node[j].kind == )
{
add(hash_(node[j].r),node[j].delt);
}
}
ans[node[i].idx] += sum(hash_(node[i].r));
}
}
for (int i = l; i < j; i++)
if ( node[i].kind == )
add(hash_(node[i].r),-node[i].delt);
inplace_merge(node+l,node+mid+,node+r+);
}
int vis[maxn];
int main(void)
{
#ifndef ONLINE_JUDGE
freopen("in.txt","r",stdin);
#endif
int n;
while (~scanf ("%d",&n))
{
int cnt = ;
vec_idx = ;
memset(arr,,sizeof(arr));
memset(ans,,sizeof(ans));
memset(vis,,sizeof(vis));
vector<int>vv;
for (int i = ; i <= n; i++)
{
char op[];
scanf ("%s",op);
if (op[] == 'D')
{
scanf ("%d%d",&node[i].l,&node[i].r);
node[i].kind = ;
node[i].idx = i;
node[i].delt = ;
vec[vec_idx++] = node[i].r;
vv.push_back(i);
}
if (op[] == 'Q')
{
scanf ("%d%d",&node[i].l,&node[i].r);
node[i].kind = ;
node[i].idx = i;
vec[vec_idx++] = node[i].r;
vis[i] = ;
}
if (op[] == 'C')
{
int tmp;
scanf ("%d",&tmp);
node[i].kind = ;
node[i].l = node[vv[tmp-]].l;
node[i].r = node[vv[tmp-]].r;
node[i].delt = -; // 对于删除的边类型与增加的相同但是,操作的时候是-1
node[i].idx = i;
}
}
sort(vec,vec+vec_idx);
vec_idx = unique(vec,vec+vec_idx) - vec;
MAX = vec_idx + ;
CDQ(,n);
for (int i = ; i <= n; i++)
{
if (vis[i])
printf("%d\n",ans[i]);
}
}
return ;
}
Acdream1157---Segments (CDQ分治)的更多相关文章
- ACdream 1157 Segments CDQ分治
题目链接:https://vjudge.net/problem/ACdream-1157 题意: Problem Description 由3钟类型操作: 1)D L R(1 <= L < ...
- 【ACdream】1157 Segments cdq分治
Segments Problem Description 由3钟类型操作:1)D L R(1 <= L <= R <= 1000000000) 增加一条线段[L,R]2)C i ...
- ACdream1157 Segments(CDQ分治 + 线段树)
题目这么说的: 进行如下3种类型操作:1)D L R(1 <= L <= R <= 1000000000) 增加一条线段[L,R]2)C i (1-base) 删除第i条增加的线段, ...
- ACdream 1157 Segments(CDQ分治)
题目链接:http://acdream.info/problem?pid=1157 Problem Description 由3钟类型操作:1)D L R(1 <= L <= R < ...
- ACdream 1157 (cdq分治)
题目链接 Segments Time Limit: 4000/2000MS (Java/Others)Memory Limit: 20000/10000KB (Java/Others) Problem ...
- 【教程】简易CDQ分治教程&学习笔记
前言 辣鸡蒟蒻__stdcall终于会CDQ分治啦! CDQ分治是我们处理各类问题的重要武器.它的优势在于可以顶替复杂的高级数据结构,而且常数比较小:缺点在于必须离线操作. CDQ分治的基 ...
- BZOJ 2683 简单题 ——CDQ分治
[题目分析] 感觉CDQ分治和整体二分有着很本质的区别. 为什么还有许多人把他们放在一起,也许是因为代码很像吧. CDQ分治最重要的是加入了时间对答案的影响,x,y,t三个条件. 排序解决了x ,分治 ...
- HDU5618 & CDQ分治
Description: 三维数点 Solution: 第一道cdq分治...感觉还是很显然的虽然题目不能再傻逼了... Code: /*=============================== ...
- 初识CDQ分治
[BZOJ 1176:单点修改,查询子矩阵和]: 1176: [Balkan2007]Mokia Time Limit: 30 Sec Memory Limit: 162 MBSubmit: 200 ...
- HDU5322 Hope(DP + CDQ分治 + NTT)
题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5322 Description Hope is a good thing, which can ...
随机推荐
- JAVA冒泡排序/JAVA冒泡排序再找出给定数据中的最大值最小值/JAVA数组排序
//数组中排序 int in[] = {1,6,5,8,9}; Arrays.sort(in); for(int i=0;i<in.length;i++){ Sys ...
- [转] 强大的python字符串解析
1.python字符串通常有单引号('...').双引号("...").三引号("""...""")或('''...'' ...
- yii cgridview 如何显示图片
发布的新闻或介绍里有图片,图片存的是Url地址,通过yii的cgridview,默认是数据库里存的啥就显示啥,如何把url地址转为图片?直接上代码 <?php $data = $model-&g ...
- UML简易看懂
这是一堂关于UML基础知识的补习课:现在我们做项目时间都太紧了,基本上都没有做过真正的class级别的详细设计,更别提使用UML来实现规范建模了:本篇主要就以前自己一直感觉很迷糊的几种class之间的 ...
- 判断直线与线段相交 POJ 3304 Segments
题意:在二维平面中,给定一些线段,然后判断在某直线上的投影是否有公共点. 转化,既然是投影,那么就是求是否存在一条直线L和所有的线段都相交. 证明: 下面给出具体的分析:先考虑一个特殊的情况,即n=1 ...
- Genymotion 模拟器 VirtualBox
准备 介绍: 1.Genymotion安卓模拟器其实不是普通的模拟器,严格来说,genymotion是虚拟机,被网传定义为模拟器,加载APP的速度比较快,操作起来也很流畅.2.Genymotion依赖 ...
- RadioGroup单选按钮排版
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools= ...
- BetWeen和模糊查询
--区分大小写性能比较低select * from Students where Age >1 and Age <4select * from Students where Age bet ...
- 装饰(Decorator)模式
1.装饰(Decorator)模式 动态给一个对象添加一些额外的职责.就增加功能来说,装饰模式比生成子类更为灵活.Component是定义一个对象接口.可以给这些对象动态地添加职责.Concre ...
- 东软实训1 -jsp内置对象及其常用方法
JSP 的内置对象及方法详细说明 一. request 对象 客户端的请求信息被封装在 request 对象中,通过它才能了解到客户的需 求,然后做出响应.它是 HttpServletRequest ...