[HDU5592] ZYB's Premutation

题目大意:一个由\([1,n]\)组成的数列,但不知道具体排列,但给出每个前缀的逆序对数目,让你还原排列

Solution

创造一颗\([1,n]\)的权值线段树,初始权值都为\(1\),我们从后往前离线处理,每次拿到一个前缀的逆序对数\(p[i]\),说明在\(i\)上的这个数字\(a_i\)前面有\(sum=p[i]-p[i-1]\)个数字比它大,所以\(a_i\)是\(a_1,\cdots ,a_i\)中第\(i -sum\)大的数字,查询后这个\(a_i\)对前面就没有用了,需要在权值线段树上删去

Code

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#define sc(x) scanf("%d", &x)
#define pf(x) printf("%d\n",x)
#define lson cur << 1
#define rson (cur << 1) | 1 const int N = 50005; int num[N << 2], val[N << 2];
int p[N], ans[N];
int n; void build(int cur, int l, int r){
num[cur] = r - l + 1;
if(l == r){
val[cur] = l;
return;
}else{
int mid = l + ((r - l) >> 1);
build(lson, l, mid);
build(rson, mid + 1, r);
}
} int query(int cur, int l, int r, int k){
int mid = l + ((r - l) >> 1);
if(l == r){
// pf(val[cur]);
return val[cur];
}else{
if(num[lson] >= k){
return query(lson, l, mid, k);
}else{
return query(rson, mid + 1, r, k - num[lson]);
}
}
} void update(int cur, int l, int r, int k){
num[cur]--;
if(l == r){
val[cur] = 0;
return;
}else{
int mid = l + ((r - l) >> 1);
if(k <= mid){
update(lson, l, mid, k);
}else{
update(rson, mid + 1, r, k);
}
}
} int main(){
int t;
scanf("%d", &t);
while(t--){
scanf("%d", &n);
memset(num, 0, sizeof(num));
memset(val, 0, sizeof(val));
build(1, 1, n + 1);//l和r要和数组对应起来,不能建的时候是n+1,query和update时又变成了n
for(int i = 1, la; i <= n; ++i){
scanf("%d", &p[i]);
}
for(int i = n; i; --i){
ans[i] = query(1, 1, n + 1, i - p[i] + p[i - 1]);
update(1, 1, n + 1, ans[i]);
}
for(int i = 1; i < n; ++i){
printf("%d ", ans[i]);
}
printf("%d\n", ans[n]);
}
return 0;
}

Error

  • \(l\)和\(r\)要和数组对应起来,不能建的时候是\(n+1\),\(query\)和\(update\)时又变成了\(n\)

最新文章

  1. Lambda
  2. Your stream was neither an OLE2 stream, nor an OOXML stream.问题的解决
  3. android wifi Direct Audio TX/RX延迟分析
  4. PHP项目感悟 -- 从CI框架来看iOS的MVC
  5. iOS学习21之UILabel, UITextField, UIButton, UIImageView
  6. 黑马程序员——【Java基础】——File类、Properties集合、IO包中的其他类
  7. iOS遍历程序内某个文件夹下所有文件的属性
  8. marquee标签属性详解(跑马灯文字效果)
  9. Page_Init 的执行过程
  10. Vi的使用
  11. HTTP 417解决方案
  12. 2、Lucene 最简单的使用(小例子)
  13. linux如何执行后台进程
  14. 设计模式C++达到 1.辛格尔顿
  15. Android 使用Gson解析json案例具体解释
  16. phpredis扩展
  17. Spark官方1 ---------Spark SQL和DataFrame指南(1.5.0)
  18. css定位讲解
  19. JDK1.7中HashMap底层实现原理
  20. React从入门到放弃之前奏(4):Redux中间件

热门文章

  1. Oracle数据库故障处理方法
  2. 关于rand()
  3. 进程控制——fork-and-exec、system、wait
  4. Docker--Image and Container
  5. 大数据开发--Hbase协处理器案例
  6. 1. mac 手动安装nodejs搭建vue环境
  7. Emacs和Vim:神的编辑器和编辑器之神, 到底哪个更好?
  8. 转换 React 为TypeScript
  9. js &amp; touch &amp; pull down &amp; load more
  10. 可视化埋点 &amp; XPath