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 ...
随机推荐
- 异步套接字编程之select模型
█ 选择(select)模型是Winsock中最常见的 I/O模型.核心便是利用 select 函数,实现对 I/O的管理!利用 select 函数来判断某Socket上是否有数据可读,或者能否向 ...
- DHTML【1】
什么是DHTML呢?英文全称(Dynamic Hypertext Markup Language),即动态超文本标记语言,DHTML不是一个独立的新技术,而是多种技术的综合,它能使HTML变的更 ...
- [转] 查看CPU使用率 top命令详解
一 top是一个动态显示过程,即可以通过用户按键来不断刷新当前状态.如果在前台执行该命令,它将独占前 台,直到用户终止该程序为止. 比较准确的说,top命令提供了实时的对系统处理器的状态监视.它将显示 ...
- csv操作帮助类
功能描述: 集合转换为csv数据 DataSe转换为csv数据 using System; using System.Collections.Generic; using System.Data; u ...
- Android组件系列----BroadcastReceiver广播接收器
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/3 ...
- PullToRefresh下拉刷新 加载更多 详解 +示例
常用设置 项目地址:https://github.com/chrisbanes/Android-PullToRefresh a. 设置刷新模式 如果Mode设置成Mode.PULL_FROM_STAR ...
- ProGuard 代码混淆
简介 Java代码是非常容易反编译的.为了很好的保护Java源代码,我们往往会对编译好的class文件进行混淆处理. ProGuard是一个混淆代码的开源项目.它的主要作用就是混淆,当然它还能对字节码 ...
- C#之Linq学习笔记【转】
写在前面 其实在09年就已经学习过Linq了,并被她那优美的语法所吸引,只是现在所在的公司还在使用VS2005在.Net2.0的框架下面的开发,所以Linq也很久没有用过了,最近看部门的同事对这个有些 ...
- Error prompt:“wget: unable to resolve host address”---Solution
//Situation System prompts that:"wget: unable to resolve host address". //Analysis Una ...
- linux的make install命令
tar zxvf redis-2.8.15.tar.gz cd redis-2.8.15/ make make test make install