51nod1364 最大字典序排列
不断的在cur的后面找最大的符合条件的数扔到cur的前面。 用线段树维护操作就可以了。
#include<cstdio>
#include<cstring>
#include<cctype>
#include<algorithm>
using namespace std;
#define rep(i,s,t) for(int i=s;i<=t;i++)
#define dwn(i,s,t) for(int i=s;i>=t;i--)
#define clr(x,c) memset(x,c,sizeof(x))
#define lson l,mid,x<<1
#define rson mid+1,r,x<<1|1
int read(){
int x=0;char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) x=x*10+c-'0',c=getchar();
return x;
}
const int nmax=1e5+5;
int a[nmax],mx[nmax<<2],pos[nmax<<2],sm[nmax<<2];
void pushup(int x){
int a=x<<1,b=x<<1|1;
sm[x]=sm[a]+sm[b];
if(mx[a]<mx[b]) mx[x]=mx[b],pos[x]=pos[b];
else mx[x]=mx[a],pos[x]=pos[a];
}
void build(int l,int r,int x){
if(l==r){
mx[x]=a[l],pos[x]=l,sm[x]=1;return ;
}
int mid=(l+r)>>1;build(lson);build(rson);
pushup(x);
}
struct node{
int mx,pos;
node(int mx,int pos):mx(mx),pos(pos){};
node(){};
};
int query(int l,int r,int x,int p){
if(l==r) return l;
int mid=(l+r)>>1;
if(p<=sm[x<<1]) return query(lson,p);
return query(rson,p-sm[x<<1]);
}
int query_sm(int l,int r,int x,int tl,int tr){
if(tl<=l&&tr>=r) return sm[x];
int mid=(l+r)>>1,ans=0;
if(tl<=mid) ans+=query_sm(lson,tl,tr);
if(tr>mid) ans+=query_sm(rson,tl,tr);
return ans;
}
node query_mx(int l,int r,int x,int tl,int tr){
if(tl<=l&&tr>=r) return node(mx[x],pos[x]);
int mid=(l+r)>>1;node ans=node(0,0),t;
if(tl<=mid) ans=query_mx(lson,tl,tr);
if(tr>mid) {
t=query_mx(rson,tl,tr);
if(t.mx>ans.mx) ans=t;
}
return ans;
}
void del(int l,int r,int x,int p){
if(l==r) mx[x]=pos[x]=sm[x]=0;
else{
int mid=(l+r)>>1;
p<=mid?del(lson,p):del(rson,p);
pushup(x);
}
}
int main(){
int n=read(),m=read();
rep(i,1,n) a[i]=read();
build(1,n,1);
int cur=1,u,v,d,tmp,temp,cnt=0;node o;
rep(i,1,n){
if(++cnt>n) break;
u=query(1,n,1,m+1);
o=query_mx(1,n,1,i,u);
printf("%d\n",o.mx);
del(1,n,1,o.pos);
m-=query_sm(1,n,1,1,o.pos);
if(o.pos!=i) --i;
}
return 0;
}
第1行:2个数N, K中间用空格分隔(1 <= N <= 100000, 0 <= K <= 10^9)。
第2至N + 1行:每行一个数i(1 <= i <= N)。
输出共N行,每行1个数,对应字典序最大的排列的元素。
5 6
1
2
3
4
5
5
3
1
2
4
51nod1364 最大字典序排列的更多相关文章
- [51nod-1364]最大字典序排列
[51nod-1364]最大字典序排列 Online Judge:51nod-1364 Label:线段树,树状数组,二分 题目描述 题解: 根据题意很容易想到60%数据的\(O(N^2logN)\) ...
- 51Node 1364--- 最大字典序排列(树状数组)
51Node 1364--- 最大字典序排列(树状数组) 1364 最大字典序排列 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 收藏 关注 给出一个1至N ...
- 51nod 1364 最大字典序排列(线段树)
1364 最大字典序排列基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 给出一个1至N的排列,允许你做不超过K次操作,每次操作可以将相邻的两个数交换,问能够得到的字 ...
- [Swift-2019力扣杯春季决赛]2. 按字典序排列最小的等效字符串
给出长度相同的两个字符串:A 和 B,其中 A[i] 和 B[i] 是一组等价字符.举个例子,如果 A = "abc" 且 B = "cde",那么就有 'a' ...
- [leetcode](4.21)2. 按字典序排列最小的等效字符串
给出长度相同的两个字符串:A 和 B,其中 A[i] 和 B[i] 是一组等价字符.举个例子,如果 A = "abc" 且 B = "cde",那么就有 'a' ...
- hdu1027(n个数的按字典序排列的第m个序列)
题目信息:给出n.m,求n个数的按字典序排列的第m个序列 http://acm.hdu.edu.cn/showproblem.php? pid=1027 AC代码: /** *全排列的个数(次序) ...
- poj 1146 ID Codes (字符串处理 生成排列组合 生成当前串的下一个字典序排列 【*模板】 )
ID Codes Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 6229 Accepted: 3737 Descript ...
- 46. 47. Permutations and Permutations II 都适用(Java,字典序 + 非字典序排列)
解析: 一:非字典序(回溯法) 1)将第一个元素依次与所有元素进行交换: 2)交换后,可看作两部分:第一个元素及其后面的元素: 3)后面的元素又可以看作一个待排列的数组,递归,当剩余的部分只剩一个元素 ...
- POJ-1318(list.sort()输出不为字典序,map才是按字典序排列)
#include<iostream> #include<string> #include<list> #include<map> #include< ...
随机推荐
- python笔记1
1.python中的语句块是用缩进表示,并不像C类语言中用{}表示语句块,还有就是语句块的开始貌似是用:表示,然后C类语言中()在python中用"空格"表示了,例如python中 ...
- shell脚本 -d 是目录文件,那么-e,-f分别是什么?还有"! -e"这又是什么意思呢?
-e filename 如果 filename存在,则为真-d filename 如果 filename为目录,则为真 -f filename 如果 filename为常规文件,则为真-L filen ...
- 40页PPT告诉你真正的"互联网+"
点这里 40页PPT告诉你真正的"互联网+" 2015-04-06 网站分析公会 超过50万名互联网从业人士关注 互联网运营领域最具影响力自媒体 本文根据和君赵大伟关于互联网思维大 ...
- android开发环境搭建(for 驱动开发人员)
前言 一.android驱动的开发流程 1: 写LINUX驱动 2: 写LINUX应用测试程序 3: 写JNI接口,用来包装第二步写的应用 (要用NDK来编译) 生成一个.SO文件,相当于CE下的DL ...
- $q -- AngularJS中的服务
此 承诺/延迟(promise/deferred)实现 的灵感来自于 Kris Kowal's QCommonJS Promise建议文档 将承诺(promise) 作为和 异步执行操作(action ...
- ***百度统计图表Echarts的php实现类,支持柱形图、线形图、饼形图
/** * 百度数据统计图表echart的PHP实现类 * * 原作者: * @author: chenliujin <liujin.chen@qq.com> * @since 2013- ...
- redis命令参考
http://doc.redisfans.com/ 进入redis命令行模式方式: 1.进入redis安装目录 2.运行redis-cli
- 数学+dp HDOJ 5317 RGCDQ
题目传送门 /* 题意:给一个区间,问任意两个数的素数因子的GCD最大 数学+dp:预处理出f[i],发现f[i] <= 7,那么用dp[i][j] 记录前i个f[]个数为j的数有几个, dp[ ...
- 今天来做一个PHP电影小爬虫。
今天来做一个PHP电影小爬虫.我们来利用simple_html_dom的采集数据实例,这是一个PHP的库,上手很容易.simple_html_dom 可以很好的帮助我们利用php解析html文档.通过 ...
- iOS 深拷贝和浅拷贝
注意,本文只说结论不说过程 1. 对于系统的非容器类对象,我们可以认为,如果对一不可变对象复制,copy是指针复制(浅拷贝)和mutableCopy就是对象复制(深拷贝).如果是对可变对象复制,都是深 ...