题意:在一个队列中,你知道一个人在他左边或者右边比他高的人的个数,求字典序最小的答案

思路:先将人按  矮-->高 排序,然后算出在每个人前面需要预留的位置。树状数组(也可以线段树)解决时,先二分查找合适的位置,如果合理则标记,每次查找时    枚举的人数 - 前面已占的人数 = 可预留位置

判断分别在它左边 或者 右边时可能的最小值进行比较。

预留的位置①:pnode[i].num(即比他高的人数,全在左)

②:n - ( pnode[i].num + i) (当比他高,和前面加入的全在右边时) //为了字典序最小

/* 当时是一点头绪都没有- -,没想到是可以用线段树和二维数组,果然太年轻

#include <cstdio>
#include <cstring>
#include <algorithm>
#define MAXN 100010
using namespace std; const int N = 1e5 + 5;
int n,m;
int tree[N];
struct node
{
int id,num,position;
}pnode[N]; bool cmp(node a,node b)
{
return a.id < b.id;
}
bool cmp2(node a,node b)
{
return a.position < b.position;
} void add(int x , int dx)
{
while(x < N)
{
tree[x] += dx ;
x += x&(-x) ;
}
}
int query(int x)
{
int sum = 0 ;
while(x)
{
sum += tree[x] ;
x -= x&(-x) ;
}
return sum ;
} int fin(int l,int r,int x)
{
if(x < 0)
return -1;
while(l <= r)
{
int mid = (l + r)/2;
int tt= mid - query(mid); //找出前面有多少空位
if(tt < x)
l =mid + 1;
else
r = mid - 1;
}
return l;
} void ini()
{
for(int i = 0;i <= n;i++)
tree[i] = 0;
} int main()
{
int t,cas = 1;
scanf("%d",&t);
while(t--)
{
scanf("%d",&n); for(int i = 1;i <= n;i++)
scanf("%d%d",&pnode[i].id,&pnode[i].num);
sort(pnode+1,pnode+1+n,cmp);
ini();
int flag = 0;
for(int i = 1;i <= n;i++)
{
int p = n - (i - 1) ; //求还剩下多少位置
int tp = pnode[i].num;
if(p <= tp) //判断剩下的能否预留合理位置
flag = true;
int x1 = fin(1,n,pnode[i].num + 1);
int x2 = fin(1,n,n -pnode[i].num-i + 1);
pnode[i].position = min(x1,x2);
add(pnode[i].position,1);
} printf("Case #%d: ", cas++);
if(flag )
{
printf("impossible\n");
continue;
}
sort(pnode+1,pnode+n+1,cmp2);
printf("%d", pnode[1].id);
for (int i = 2; i <= n; i++)
printf(" %d", pnode[i].id);
printf("\n"); }
return 0;
}

  

ps.如果没有东西值得你为之努力,那你和一条咸鱼有什么区别? 

hdu 5493 (树状数组)的更多相关文章

  1. hdu 4638 树状数组 区间内连续区间的个数(尽可能长)

    Group Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  2. hdu 4777 树状数组+合数分解

    Rabbit Kingdom Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) T ...

  3. Q - Queue HDU - 5493(树状树组维护区间前缀和 + 二分找预留空位)

    Q - Queue HDU - 5493 Problem Description NNN people numbered from 1 to NNN are waiting in a bank for ...

  4. HDU 2852 (树状数组+无序第K小)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2852 题目大意:操作①:往盒子里放一个数.操作②:从盒子里扔掉一个数.操作③:查询盒子里大于a的第K小 ...

  5. HDU 4911 (树状数组+逆序数)

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4911 题目大意:最多可以交换K次,就最小逆序对数 解题思路: 逆序数定理,当逆序对数大于0时,若ak ...

  6. hdu 5792(树状数组,容斥) World is Exploding

    hdu 5792 要找的无非就是一个上升的仅有两个的序列和一个下降的仅有两个的序列,按照容斥的思想,肯定就是所有的上升的乘以所有的下降的,然后再减去重复的情况. 先用树状数组求出lx[i](在第 i ...

  7. HDU 1934 树状数组 也可以用线段树

    http://acm.hdu.edu.cn/showproblem.php?pid=1394 或者是我自己挂的专题http://acm.hust.edu.cn/vjudge/contest/view. ...

  8. 2018 CCPC网络赛 1010 hdu 6447 ( 树状数组优化dp)

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=6447 思路:很容易推得dp转移公式:dp[i][j] = max(dp[i][j-1],dp[i-1][j ...

  9. 【模板】HDU 1541 树状数组

    http://acm.hdu.edu.cn/showproblem.php?pid=1541 题意:给你一堆点,每个点右一个level,为其右下方所有点的数量之和,求各个level包含的点数. 题解: ...

  10. hdu 5147 树状数组

    题意:求满足a<b<c<d,A[a]<A[b],A[c]<A[d]的所有四元组(a,b,c,d)的个数 看到逆序对顺序对之类的问题一开始想到了曾经用归并排序求逆序对,结果 ...

随机推荐

  1. equalsignorecase 和equals的区别

    equals方法来自于Object类equalsIgnoreCase方法来自String类equals对象参数是Object 用于比较两个对象是否相等equals在Object类中方法默然比较对象内存 ...

  2. Android实验报告

    实验名称:Android程序设计 实验时间:2017.5.24 实验人员:20162309邢天岳(结对同学20162313苑洪铭) 实验目的:使用android stuidio开发工具进行基本安卓软件 ...

  3. 关于第一次使用vue-cli

    前段时间终于终于可以用vue-cli,webpack做个企业站,记一下过程... 首先node.js,按照vue官网的步骤命令提示符走一波,网速原因,所以用的是淘宝镜像 cnpm # 全局安装 vue ...

  4. 修改MYSQL的默认连接时长

    show global variables like 'wait_timeout'; 设置成10小时; set global wait_timeout=36000;

  5. vuex在项目中使用的一点总结

    以下为vue后台管理项目中使用vuex的一点总结,截取了其中部分代码,如有什么错误,还望指出. 1. token 存储 登陆成功之后,需要把获取到的 token 存储到 vuex 中,配合 axios ...

  6. eclipse+Maven插件报错:-Dmaven.multiModuleProjectDirectory system propery is not set. Check $M2_HOME environment variable and mvn script match.

    问题描述: eclipse indigo+maven3.3.3+jdk1.70 maven插件执行报错:-Dmaven.multiModuleProjectDirectory system prope ...

  7. 阿里云API网关(12)为员工创建子账号,实现分权管理API:使用RAM管理API

    网关指南: https://help.aliyun.com/document_detail/29487.html?spm=5176.doc48835.6.550.23Oqbl 网关控制台: https ...

  8. hadoop2.7.3+spark2.1.0+scala2.12.1环境搭建(4)SPARK 安装

    hadoop2.7.3+spark2.1.0+scala2.12.1环境搭建(4)SPARK 安装 一.依赖文件安装 1.1 JDK 参见博文:http://www.cnblogs.com/liugh ...

  9. Web框架之Django基础篇

    Web框架之Django基础篇   本节介绍Django 简介,安装 基本配置及学习  路由(Urls).视图(Views).模板(Template).Model(ORM). 简介 Django 是一 ...

  10. python常用运算符

    1. / 浮点除法,就算分子分母都是int类型,也返回float类型,比如我们用4/2,返回2.0 2. // 整数除法,根据分子分母的不同组合,返回的值有差异. 正数//正数,取整,比如5//3,返 ...