洛谷P4390 Mokia CDQ分治
喜闻乐见的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分治的更多相关文章
- 洛谷P3810 陌上花开 CDQ分治(三维偏序)
好,这是一道三维偏序的模板题 当然没那么简单..... 首先谴责洛谷一下:可怜的陌上花开的题面被无情的消灭了: 这么好听的名字#(滑稽) 那么我们看了题面后就发现:这就是一个三维偏序.只不过ans不加 ...
- [洛谷P4390][BOI2007]Mokia 摩基亚
题目大意: 维护一个W*W的矩阵,每次操作可以增加某格子的权值,或询问某子矩阵的总权值. 题解:CDQ分治,把询问拆成四个小矩形 卡点:无 C++ Code: #include <cstdio& ...
- BZOJ 1176: [Balkan2007]Mokia( CDQ分治 + 树状数组 )
考虑cdq分治, 对于[l, r)递归[l, m), [m, r); 然后计算[l, m)的操作对[m, r)中询问的影响就可以了. 具体就是差分答案+排序+离散化然后树状数组维护.操作数为M的话时间 ...
- BZOJ 1176 Mokia CDQ分治+树状数组
1176: [Balkan2007]Mokia Time Limit: 30 Sec Memory Limit: 162 MBSubmit: 1854 Solved: 821[Submit][St ...
- BZOJ 1176[Balkan2007]Mokia(CDQ分治)
1176: [Balkan2007]Mokia Time Limit: 30 Sec Memory Limit: 162 MBSubmit: 3381 Solved: 1520[Submit][S ...
- [洛谷P3806] [模板] 点分治1
洛谷 P3806 传送门 这个点分治都不用减掉子树里的了,直接搞就行了. 注意第63行 if(qu[k]>=buf[j]) 不能不写,也不能写成>. 因为这个WA了半天...... 如果m ...
- BZOJ 1176: [Balkan2007]Mokia [CDQ分治]
题意: 有一个n * n的棋盘,每个格子内有一个数,初始的时候全部为0.现在要求维护两种操作: 1)Add:将格子(x, y)内的数加上A. 2)Query:询问矩阵(x0, y0, x1, y1)内 ...
- [bzoj1176]Mokia[CDQ分治]
啃了一天论文,发现CDQ分治的原理其实很简单,大概就是这样的一类分治:将左右区间按一定规律排序后分开处理,递归到底时直接计算答案,对于一个区间,按照第二关键字split成两个区间,先处理左区间,之后因 ...
- 洛谷 P4390 [BOI2007]Mokia 摩基亚 解题报告
P4390 [BOI2007]Mokia 摩基亚 题目描述 摩尔瓦多的移动电话公司摩基亚(\(Mokia\))设计出了一种新的用户定位系统.和其他的定位系统一样,它能够迅速回答任何形如"用户 ...
随机推荐
- “耐撕”团队 2016.03.31 站立会议
1. 时间: 19:30--19:50 共计20分钟. 2. 成员: Z 郑蕊 * 组长 (博客:http://www.cnblogs.com/zhengrui0452/), P 濮成林(博客:ht ...
- windows10企业版2016长期服务版激活
win10 2016 长期服务版的ISO文件中本身就带有KMS激活KEY,不用输入任何KEY,连接网络进入CMD,只要输入:slmgr /skms kms.digiboy.irslmgr /ato这两 ...
- 配置Google Gmail分类和过滤器
简单的记两笔. 首先点击右上角的⚙️里面选择settings. 选择Filters and Blocked Addresses 在这个页面可以选择 create a new filter创建一个新的过 ...
- 索引使用,分析初探。(explain分析执行计划,以及强制使用force index)
促使这次探索的初衷还是因为要对一个定时脚本性能进行优化. 脚本有两个指定状态分别是status, latest_process_status,和一个超期时间expire_time进行限制. 按照我以前 ...
- git format-patch制作内核补丁
git init git add ./ git commit 之后修改代码 修改代码后执行 git add ./ git commit 执行完成后执行git log查询commit 的id 执行git ...
- React Native & Google & Proxy
React Native & Google & Proxy https://snack.expo.io/ https://expo.io/snacks/@xgqfrms https:/ ...
- 销售合同金额数据从Excel导入
一.业务需求 1.新增了销售合同金额的字段,但是老数据没有这个字段:所以销售合同金额从销售合同附件的各品种金额之和. 2.制作好excel字段模板,将此模板发送给销售业务部门来统计并完成excel表格 ...
- 比特币中的Base58 编码
base58和base64一样是一种二进制转可视字符串的算法,主要用来转换大整数值.区别是,转换出来的字符串,去除了几个看起来会产生歧义的字符,如 0 (零), O (大写字母O), I (大写的字母 ...
- How to execute a Stored Procedure with Entity Framework Code First
Recently I worked on a project, which I started as code first and then I forced to switch to Databas ...
- 关于jQuery.when()用法
1.该方法在jQuery1.5开始被引入. 2.用法测试 a. var url1 = "/resource/ar/hometab/index_tab_games.json", ur ...