[CC-CHEFINV]Chef and Swaps

题目大意:

长度为\(n(n\le2\times10^5)\)的数列,\(q(q\le2\times10^5)\)次询问,每次问交换\(A_x\)和\(A_y\)后逆序对个数。询问互相独立。

思路:

一开始先把逆序对求好,然后用主席树计算交换对答案的影响即可。

时间复杂度\(\mathcal O((n+q)\log n)\)。

源代码:

#include<cstdio>
#include<cctype>
#include<vector>
#include<algorithm>
inline int getint() {
register char ch;
while(!isdigit(ch=getchar()));
register int x=ch^'0';
while(isdigit(ch=getchar())) x=(((x<<2)+x)<<1)+(ch^'0');
return x;
}
typedef long long int64;
const int N=2e5+1,logN=20;
int n,m,a[N];
std::vector<int> v;
class FenwickTree {
private:
int val[N];
int lowbit(const int &x) const {
return x&-x;
}
public:
void modify(int p) {
for(;p<=m;p+=lowbit(p)) val[p]++;
}
int query(int p) const {
int ret=0;
for(;p;p-=lowbit(p)) ret+=val[p];
return ret;
}
};
FenwickTree bit;
class FotileTree {
#define mid ((b+e)>>1)
private:
struct Node {
int val,left,right;
};
Node node[N*logN];
int sz,new_node(const int &p) {
node[++sz]=node[p];
return sz;
}
public:
int root[N];
void insert(int &p,const int &b,const int &e,const int &x) {
p=new_node(p);
node[p].val++;
if(b==e) return;
if(x<=mid) insert(node[p].left,b,mid,x);
if(x>mid) insert(node[p].right,mid+1,e,x);
}
int query(const int &p,const int &q,const int &b,const int &e,const int &l,const int &r) const {
if(b==l&&e==r) return node[q].val-node[p].val;
int ret=0;
if(l<=mid) ret+=query(node[p].left,node[q].left,b,mid,l,std::min(mid,r));
if(r>mid) ret+=query(node[p].right,node[q].right,mid+1,e,std::max(mid+1,l),r);
return ret;
}
#undef mid
};
FotileTree t;
int main() {
n=getint();
const int q=getint();
for(register int i=1;i<=n;i++) {
a[i]=getint();
v.push_back(a[i]);
}
std::sort(v.begin(),v.end());
v.resize(m=std::unique(v.begin(),v.end())-v.begin());
for(register int i=1;i<=n;i++) {
a[i]=std::lower_bound(v.begin(),v.end(),a[i])-v.begin()+1;
}
int64 tot=0;
for(register int i=n;i>=1;i--) {
tot+=bit.query(a[i]-1);
bit.modify(a[i]);
}
for(register int i=1;i<=n;i++) {
t.insert(t.root[i]=t.root[i-1],1,m,a[i]);
}
for(register int i=0;i<q;i++) {
int x=getint(),y=getint();
if(x>y) std::swap(x,y);
const int tmp1=a[x]!=1?t.query(t.root[x],t.root[y],1,m,1,a[x]-1):0;
const int tmp2=a[x]!=m?t.query(t.root[x],t.root[y],1,m,a[x]+1,m):0;
const int tmp3=a[y]!=1?t.query(t.root[x],t.root[y],1,m,1,a[y]-1):0;
const int tmp4=a[y]!=m?t.query(t.root[x],t.root[y],1,m,a[y]+1,m):0;
printf("%lld\n",tot-tmp1+tmp2+tmp3-tmp4);
}
return 0;
}

最新文章

  1. BizTalk动手实验(十七)ODBC适配器使用
  2. jqurey的跨域使用getjson(http://www.jb51.net/Special/894.htm)
  3. CSS继承总结
  4. CentOS 6.5 安装Python 3.5
  5. windows编程中关于“关闭窗口无法退出进程”的解决方法
  6. Windows batch,echo到文件不成功,只打印出ECHO is on.
  7. MVC(模型-视图-控制器)的理解
  8. mac 下 svn ignore 操作
  9. POJ 1088 滑雪 (记忆化搜索)
  10. 设计模式(十二): Flyweight享元模式 -- 结构型模式
  11. C++中构造函数初始化成员列表总结
  12. oracle form 触发器执行顺序及键定义[Z]
  13. 线段树扫描线 HDU 1542
  14. Mybatis接口编程原理分析(二)
  15. 【递归打卡2】求两个有序数组的第K小数
  16. 重装助手教你如何禁用Windows 10快速启动
  17. Java 中的伪共享详解及解决方案
  18. UVALive 4850 Installations 贪心
  19. py 正在爬取第%d页的美眉图
  20. [转]深入理解Java之线程池

热门文章

  1. 使用solr批量导入mysql数据库,以及Unable to read: dataimport.properties等坑
  2. 【codeforces】【比赛题解】#851 CF Round #432 (Div.2)
  3. 【转】Spring MVC 标签总结
  4. aarch64_l1
  5. FastDFS集群部署
  6. Filebeat入门
  7. KnockoutJs学习笔记(二)
  8. 如何解决vuex因浏览器刷新数据消失,保持数据持久化问题?
  9. C#socket编程序(三)
  10. CROC 2016 - Elimination Round (Rated Unofficial Edition) F - Cowslip Collections 数论 + 容斥