【BZOJ 3295】动态逆序对 - 分块+树状数组
题目描述
给定一个1~n的序列,然后m次删除元素,每次删除之前询问逆序对的个数。
分析:分块+树状数组
(PS:本题的CDQ分治解法见下一篇)
首先将序列分成T块,每一块开一个树状数组,并且先把最初的答案统计完成。
对于每一次删除,找到对应位置,考虑删除之后的增减情况:
①块内:直接暴力,对于左边,少了比它大的个数,对于右边,少了比它小的个数,
②块外:枚举每一块。对于左边,少了比它大的个数,对于右边,少了比它小的个数,。
然后把这个位置的数分别从数组和树状数组中删除,。
为了最小化时间,我们使,忽略,所以取即可。
小结
一些自己不容易出错的写法:
①本题数组使用*a的方法
②涉及lint,须检验 参数声明、变量声明、函数声明、输入输出
③同一行最多只能有一类函数,且不要与其他运算,否则使用tmp
④分块的问题,直接将块的大小设为确定值,并标记块的个数上限,还有就是(i-1)/unit+1的写法
⑤对于一个参数,如果需要作空间且需要枚举,若数值上的差>1,那么开两个参数
⑥对于一个整数a判断是否大于0,写作a>0,不要写作a
代码
#include <cstdio>
#include <cctype>
#include <cmath>
#include <algorithm>
using namespace std;
typedef long long lint;
const int N=100010;
const int BLOCK_SIZE=1000;
const int BLOCK_NUM=101;
int n,m;
int a[N];
int loc[N];
lint t[N];
lint res;
int num;
lint tr[BLOCK_NUM][N];
inline int read(void)
{
int x=0; char c=getchar();
for (;!isdigit(c);c=getchar());
for (;isdigit(c);c=getchar()) x=x*10+c-'0';
return x;
}
inline int lowbit(int i)
{
return i&-i;
}
inline void ins(lint *ta,int i,int add)
{
for (;i<=n;i+=lowbit(i)) ta[i]+=add;
}
inline lint query(lint *ta,int i)
{
lint sum=0;
for (;i;i-=lowbit(i)) sum+=ta[i];
return sum;
}
inline void update(int x)
{
int loca=loc[x],bel=(loca-1)/BLOCK_SIZE+1;
for (int i=BLOCK_SIZE*(bel-1)+1;i<loca;i++)
if (a[i]>0&&a[i]>x) res--;
for (int i=loca+1;i<=min(BLOCK_SIZE*bel,n);i++)
if (a[i]>0&&a[i]<x) res--;
lint tmp;
for (int i=1;i<bel;i++)
{
tmp=query(tr[i],n)-query(tr[i],x-1);
res-=tmp;
}
for (int i=bel+1;i<=num;i++)
{
tmp=query(tr[i],x-1);
res-=tmp;
}
a[loca]=0;
ins(tr[bel],x,-1);
}
int main(void)
{
// freopen("a.in","r",stdin);
// freopen("a.out","w",stdout);
n=read(),m=read();
for (int i=1;i<=n;i++) a[i]=read();
for (int i=1;i<=n;i++) loc[a[i]]=i;
lint tmp;
for (int i=n;i>=1;i--)
{
tmp=query(t,a[i]);
res=res+tmp;
ins(t,a[i],1);
}
int belo;
num=(n-1)/BLOCK_SIZE+1;
for (int i=1;i<=n;i++)
{
belo=(i-1)/BLOCK_SIZE+1;
ins(tr[belo],a[i],1);
}
for (int i=1;i<=m;i++)
{
printf("%lld\n",res);
update(read());
}
return 0;
}
【BZOJ 3295】动态逆序对 - 分块+树状数组的更多相关文章
- Bzoj 3295: [Cqoi2011]动态逆序对 分块,树状数组,逆序对
3295: [Cqoi2011]动态逆序对 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2886 Solved: 924[Submit][Stat ...
- P3157 [CQOI2011]动态逆序对(树状数组套线段树)
P3157 [CQOI2011]动态逆序对 树状数组套线段树 静态逆序对咋做?树状数组(别管归并QWQ) 然鹅动态的咋做? 我们考虑每次删除一个元素. 减去的就是与这个元素有关的逆序对数,介个可以预处 ...
- BZOJ3295: [Cqoi2011]动态逆序对(树状数组套主席树)
3295: [Cqoi2011]动态逆序对 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 7465 Solved: 2662[Submit][Sta ...
- BZOJ3295 动态逆序对(树状数组套线段树)
[Cqoi2011]动态逆序对 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 6058 Solved: 2117[Submit][Status][D ...
- bzoj3295 [Cqoi2011]动态逆序对 cdq+树状数组
[bzoj3295][Cqoi2011]动态逆序对 2014年6月17日4,7954 Description 对于序列A,它的逆序对数定义为满足i<j,且Ai>Aj的数对(i,j)的个数. ...
- 【Luogu】P3157动态逆序对(树状数组套主席树)
题目链接 md第一道在NOILinux 下用vim做的紫题.由于我对这个操作系统不是很熟悉,似乎有什么地方搞错了,md调死.(我还打了两遍代码,调了两个小时) 但是这道题并不难,就是树状数组套上主席树 ...
- BZOJ3295 [Cqoi2011]动态逆序对 分治 树状数组
原文链接http://www.cnblogs.com/zhouzhendong/p/8678185.html 题目传送门 - BZOJ3295 题意 对于序列$A$,它的逆序对数定义为满足$i< ...
- BZOJ 3295 动态逆序对 | CDQ分治
BZOJ 3295 动态逆序对 这道题和三维偏序很类似.某个元素加入后产生的贡献 = time更小.pos更小.val更大的元素个数 + time更小.pos更大.val更小的元素个数. 分别用类似C ...
- AcWing 107. 超快速排序(归并排序 + 逆序对 or 树状数组)
在这个问题中,您必须分析特定的排序算法----超快速排序. 该算法通过交换两个相邻的序列元素来处理n个不同整数的序列,直到序列按升序排序. 对于输入序列9 1 0 5 4,超快速排序生成输出0 1 4 ...
随机推荐
- C#获取当前页面的url
C#获取当前页面的url string a= Request.ApplicationPath; // / string b = Request.CurrentExecutionFilePath; // ...
- java中局部变量和成员变量主要是他们作用域的区别
成员变量个是类内部:局部变量是定义其的方法体内部(或者方法体内部的某一程序块内——大括号,主要看定义的位置).另外,成员变量可以不显式初始化,它们可以由系统设定默认值:局部变量没有默认值,所以必须设定 ...
- HDU 1004 Let the Balloon Rise map
Let the Balloon Rise Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Oth ...
- linux内核中的GPIO系统之(2):pin control subsystem
一.前言 在linux2.6内核上工作的嵌入式软件工程师在pin control上都会遇到这样的状况: (1)启动一个新的项目后,需要根据硬件平台的设定进行pin control相关的编码.例如:在b ...
- BZOJ 1822 Frozen Nova 冷冻波(最大流)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1822 题意:WJJ喜欢“魔兽争霸”这个游戏.在 游戏中,巫妖是一种强大的英雄,它的技能F ...
- UI事件 计算器界面
1.MainActivity.java package com.example.administrator.testapp2; import android.support.v7.app.AppCom ...
- Update与FixedUpdate区别
以下的代码能使游戏暂停,记得要使速度*Time.deltaTime,目的是保证游戏运行在帧数不同的情况下,角色移动速度都一样,因为此时角色是按时间移动与帧数无关. using UnityEngine; ...
- CSS的单位及css3的calc()及line-height百分比
锚点:css中百分比减去固定元素 单位介绍 说到css的单位,大家应该首先想到的是px,也就是像素,我们在网页布局中一般都是用px,但是近年来自适应网页布局越来越多,em和百分比也经常用到了.然后随着 ...
- 02~ 一步一步教你使用 SVN之SVN 的介绍
SVN的介绍 一.学习SVN的主要内容的介绍 1.基本操作:学习SVN有哪些基本操作 2.服务器端的安装配置:SVN中必不可少的2个环境之一,会在下面的课程中介绍服务器如何去安装和配置 3.客户端软件 ...
- url 转码 urlencode和 urldecode
参考网址http://www.t086.com/code/php/function.php-urlencode.php urlencode 将字符串以 URL 编码. 语法: string urlen ...