喜闻乐见的CDQ分治被我搞的又WA又T.....

大致思路是这样的:把询问用二维前缀和的思想拆成4个子询问。然后施CDQ大法即可。

我却灵光一闪:树状数组是可以求区间和的,那么我们只拆成两个子询问不就行了?在统计的时候统计一个差值即可。

然后一交,自信40...

那么果然还是拆成4个吧...T了,60分。

然后放弃那个朴素的sort版CDQ,采用了归并,就A了。

 #include <cstdio>
#include <algorithm>
using namespace std;
const int N = ,M = ;
inline int read()
{
int ans=;char ch=getchar();
while(ch<''||ch>'') ch=getchar();
while(ch>=''&&ch<='') ans=(ans<<)+(ans<<)+ch-'',ch=getchar();
return ans;
}
struct Node
{
int x,y,k,type,t;
}node[N],temp[N];int tot;
int ask[],cnt,n;
inline bool cmp_x(Node a,Node b)
{
if(a.x!=b.x)return a.x<b.x;
return a.type<b.type;
}
inline bool cmp_t(Node a,Node b)
{
if(a.t!=b.t)return a.t<b.t;
return a.type<b.type;
}
int ta[M];
inline int lowbit(int i) {return i&(-i);}
inline void add(int x,int a)
{
if(x<=) return;
for(int i=x;i<=n;i+=lowbit(i)) ta[i]+=a;
return;
}
inline int getsum(int x)
{
if(x<=) return ; int ans=;
for(int i=x;i>;i-=lowbit(i)) ans+=ta[i];
return ans;
}
void CDQ(int l,int r)
{
if(l==r)return;
int mid=(l+r)>>;
CDQ(l,mid);CDQ(mid+,r); int i=l,j=mid+,t=;
while(j<=r||i<=mid)
{
if(j>r||(i<=mid&&node[i].x<=node[j].x))
{
if(node[i].type==) add(node[i].y,node[i].k);
temp[++t]=node[i++];
}
else
{
if(node[j].type>) node[j].k+=getsum(node[j].y);
temp[++t]=node[j++];
}
}
for(j=l;j<i;j++)
{
if(node[j].type==)add(node[j].y,-node[j].k);
}
t=;
for(i=l;i<=r;i++) node[i]=temp[++t];
return;
}
int main()
{
n=read();n=read();
int flag,x,y,xx,yy,k,time=;
flag=read();
while(flag!=)
{
time++;
if(flag==)
{
x=read();y=read();k=read();
node[++tot].x=x;
node[tot].y=y;
node[tot].k=k;
node[tot].t=time;
node[tot].type=;
}
else
{
x=read();y=read();xx=read();yy=read();
x--;y--;
node[++tot].x=xx;
node[tot].y=yy;
node[tot].t=time;
node[tot].type=;
ask[++cnt]=tot;
node[++tot].x=x;
node[tot].y=y;
node[tot].t=time;
node[tot].type=;
node[++tot].x=x;
node[tot].y=yy;
node[tot].t=time;
node[tot].type=;
node[++tot].x=xx;
node[tot].y=y;
node[tot].t=time;
node[tot].type=;
}
flag=read();
}
CDQ(,tot);
sort(node+,node+tot+,cmp_t);
for(int i=;i<=cnt;i++)
{
int p=ask[i];
int ans=node[p].k+node[p+].k-node[p+].k-node[p+].k;
printf("%d\n",ans);
}
return ;
}

AC代码:

洛谷P4390 Mokia CDQ分治的更多相关文章

  1. 洛谷P3810 陌上花开 CDQ分治(三维偏序)

    好,这是一道三维偏序的模板题 当然没那么简单..... 首先谴责洛谷一下:可怜的陌上花开的题面被无情的消灭了: 这么好听的名字#(滑稽) 那么我们看了题面后就发现:这就是一个三维偏序.只不过ans不加 ...

  2. [洛谷P4390][BOI2007]Mokia 摩基亚

    题目大意: 维护一个W*W的矩阵,每次操作可以增加某格子的权值,或询问某子矩阵的总权值. 题解:CDQ分治,把询问拆成四个小矩形 卡点:无 C++ Code: #include <cstdio& ...

  3. BZOJ 1176: [Balkan2007]Mokia( CDQ分治 + 树状数组 )

    考虑cdq分治, 对于[l, r)递归[l, m), [m, r); 然后计算[l, m)的操作对[m, r)中询问的影响就可以了. 具体就是差分答案+排序+离散化然后树状数组维护.操作数为M的话时间 ...

  4. BZOJ 1176 Mokia CDQ分治+树状数组

    1176: [Balkan2007]Mokia Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 1854  Solved: 821[Submit][St ...

  5. BZOJ 1176[Balkan2007]Mokia(CDQ分治)

    1176: [Balkan2007]Mokia Time Limit: 30 Sec  Memory Limit: 162 MBSubmit: 3381  Solved: 1520[Submit][S ...

  6. [洛谷P3806] [模板] 点分治1

    洛谷 P3806 传送门 这个点分治都不用减掉子树里的了,直接搞就行了. 注意第63行 if(qu[k]>=buf[j]) 不能不写,也不能写成>. 因为这个WA了半天...... 如果m ...

  7. BZOJ 1176: [Balkan2007]Mokia [CDQ分治]

    题意: 有一个n * n的棋盘,每个格子内有一个数,初始的时候全部为0.现在要求维护两种操作: 1)Add:将格子(x, y)内的数加上A. 2)Query:询问矩阵(x0, y0, x1, y1)内 ...

  8. [bzoj1176]Mokia[CDQ分治]

    啃了一天论文,发现CDQ分治的原理其实很简单,大概就是这样的一类分治:将左右区间按一定规律排序后分开处理,递归到底时直接计算答案,对于一个区间,按照第二关键字split成两个区间,先处理左区间,之后因 ...

  9. 洛谷 P4390 [BOI2007]Mokia 摩基亚 解题报告

    P4390 [BOI2007]Mokia 摩基亚 题目描述 摩尔瓦多的移动电话公司摩基亚(\(Mokia\))设计出了一种新的用户定位系统.和其他的定位系统一样,它能够迅速回答任何形如"用户 ...

随机推荐

  1. 查看端口占用cmd命令

    查看端口被占用的进程: 在任务管理器中结束进程:

  2. Oracle创建表空间、用户以及给用户赋权

    --创建表空间 create tablespace waterboss datafile 'd:\waterboss.dbf' size 100m autoextend on next 10m --创 ...

  3. mybatis源码分析(二)------------配置文件的解析

    这篇文章中,我们将讲解配置文件中 properties,typeAliases,settings和environments这些节点的解析过程. 一 properties的解析 private void ...

  4. RedHat 安装RabbitMQ

    (以下均以root用户执行) 1.安装配置epel源rpm -Uvh http://dl.fedoraproject.org/pub/epel/6/i386/epel-release-6-8.noar ...

  5. 洛谷 P1141 01迷宫

    看似普通的 bfs 题(实际上也不怎么难 主要是我太菜了) 题目链接:https://www.luogu.org/problemnew/show/P1141 如果直接用简单的bfs一顿求的话,会超时( ...

  6. ES 6 系列 - Promise

    一.含义 是异步编程的一种解决方案,es 6 将其变成了标准. 简单的说是一个容器,里面保存了某个未来才会结束的事件(通常是一个异步操作)的结果.语法上, Promise 是一个对象,从它可以获取异步 ...

  7. ES 6 系列 - 对于常用对象的拓展 api

    本篇中学习并记录可能会比较常用的 api ,详细请自行查找相关资料. 一.字符串的拓展 es 6 加强了对于 Unicode 的支持.javascript 允许采用 \uxxxxx 的方式表示一个字符 ...

  8. Add Languages to Your Xamarin Apps with Multilingual App Toolkit

    With Xamarin, you can extend your cross-platform apps with support for native speakers, reaching mar ...

  9. U68641 划水(swim.pas/c/cpp)

    U68641 划水(swim.pas/c/cpp) 题目背景 小小迪带你划水. 题目描述 原题 输入输出格式 输入格式: 第一行一个数 T. 接下来 T 行每行一个数表示 n 输出格式: 输出 T 行 ...

  10. django CBV视图源码分析

    典型FBV视图例子 url路由系统 from django.conf.urls import url from django.contrib import admin from luffycity.v ...