陈丹琦分治~~~其实一些数据小的时候可以用二维或者多维树状数组做的,而数据大的时候就无力的题目,都可以用陈丹琦分治解决。

题目:由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分治)的更多相关文章

  1. ACdream 1157 Segments CDQ分治

    题目链接:https://vjudge.net/problem/ACdream-1157 题意: Problem Description 由3钟类型操作: 1)D L R(1 <= L < ...

  2. 【ACdream】1157 Segments cdq分治

    Segments   Problem Description 由3钟类型操作:1)D L R(1 <= L <= R <= 1000000000) 增加一条线段[L,R]2)C i ...

  3. ACdream1157 Segments(CDQ分治 + 线段树)

    题目这么说的: 进行如下3种类型操作:1)D L R(1 <= L <= R <= 1000000000) 增加一条线段[L,R]2)C i (1-base) 删除第i条增加的线段, ...

  4. ACdream 1157 Segments(CDQ分治)

    题目链接:http://acdream.info/problem?pid=1157 Problem Description 由3钟类型操作:1)D L R(1 <= L <= R < ...

  5. ACdream 1157 (cdq分治)

    题目链接 Segments Time Limit: 4000/2000MS (Java/Others)Memory Limit: 20000/10000KB (Java/Others) Problem ...

  6. 【教程】简易CDQ分治教程&学习笔记

    前言 辣鸡蒟蒻__stdcall终于会CDQ分治啦!       CDQ分治是我们处理各类问题的重要武器.它的优势在于可以顶替复杂的高级数据结构,而且常数比较小:缺点在于必须离线操作. CDQ分治的基 ...

  7. BZOJ 2683 简单题 ——CDQ分治

    [题目分析] 感觉CDQ分治和整体二分有着很本质的区别. 为什么还有许多人把他们放在一起,也许是因为代码很像吧. CDQ分治最重要的是加入了时间对答案的影响,x,y,t三个条件. 排序解决了x ,分治 ...

  8. HDU5618 & CDQ分治

    Description: 三维数点 Solution: 第一道cdq分治...感觉还是很显然的虽然题目不能再傻逼了... Code: /*=============================== ...

  9. 初识CDQ分治

    [BZOJ 1176:单点修改,查询子矩阵和]: 1176: [Balkan2007]Mokia Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 200 ...

  10. HDU5322 Hope(DP + CDQ分治 + NTT)

    题目 Source http://acm.hdu.edu.cn/showproblem.php?pid=5322 Description Hope is a good thing, which can ...

随机推荐

  1. POJ2230 Watchcow【欧拉回路】

    Watchcow Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 6172Accepted: 2663 Special Judge ...

  2. 苹果Swift编程语言新手教程【中国版】

    Swift代码语言教程:在刚刚过去的WWDC2014大会上,苹果公司新公布了一种编程语言Swift.据悉.Swift语言继承了C语言以及Objective-C的特性,且克服了C语言的兼容性问题.对于广 ...

  3. 设计模式--迪米特法则(Lod/LKP)

    迪米特法则:(Law of Demeter, LoD),也称最少知识原则(Least Knowledge Principle, LKP) 理解:      假设两个类不必彼此直接通信,那么这两个类就不 ...

  4. Configuring the JA-SIG CAS Client --官方

    1. for Java using Spring Configuration of the CAS Client for Java via Spring IoC will depend heavily ...

  5. poj 3349 (最小表示法)

    开始按hash做的 交上去就wa 但是和标称拍了半天也没有不一样的 可能是生成的数据太水了吧... #include<iostream> #include<cstdio> #i ...

  6. linux下查看所有用户及所有用户组

    groups 查看当前登录用户的组内成员groups gliethttp 查看gliethttp用户所在的组,以及组内成员whoami 查看当前登录用户名 /etc/group文件包含所有组/etc/ ...

  7. c - 2/1, 3/2, 5/3, 8/5, 13/8...前20项的和

    double pres(const int n) { ; //分子. ; //分母. ; double tmp; ; i <= n; i++) { sum += (numerator / den ...

  8. PHP SimpleXML

    安装 SimpleXML 扩展需要 PHP 5 支持. 自 PHP 5 起,SimpleXML 函数是 PHP 核心的组成部分.无需安装即可使用这些函数. PHP 5 SimpleXML 函数 函数 ...

  9. 自定义分页标签,并使分页标签能获得url中的参数

    如题,要实现一个分页功能,其次,要让分页标签“智能一点”,在分页时能自动带上url后面的参数 <tag> <description>分页标签</description&g ...

  10. Android应用开发中关于this.context=context的理解

    在Android应用开发中,有的类里面需要声明一个Context的成员变量,然后还需要在该类的构造函数中加上this.context=context;这行代码.为什么要这么写呢?不写不行么? 先看下面 ...