51nod1364 最大字典序排列

时间:2022-08-31 11:00:32

不断的在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 秒 空间限制:131072 KB 分值: 80 难度:5级算法题
51nod1364 最大字典序排列 收藏
51nod1364 最大字典序排列 关注
给出一个1至N的排列,允许你做不超过K次操作,每次操作可以将相邻的两个数交换,问能够得到的字典序最大的排列是什么?
例如:N = 5, {1 2 3 4 5},k = 6,在6次交换后,能够得到的字典序最大的排列为{5 3 1 2 4}。
Input
第1行:2个数N, K中间用空格分隔(1 <= N <= 100000, 0 <= K <= 10^9)。
第2至N + 1行:每行一个数i(1 <= i <= N)。
Output
输出共N行,每行1个数,对应字典序最大的排列的元素。
Input示例
5 6
1
2
3
4
5
Output示例
5
3
1
2
4

51nod1364 最大字典序排列的更多相关文章

  1. &lbrack;51nod-1364&rsqb;最大字典序排列

    [51nod-1364]最大字典序排列 Online Judge:51nod-1364 Label:线段树,树状数组,二分 题目描述 题解: 根据题意很容易想到60%数据的\(O(N^2logN)\) ...

  2. 51Node 1364--- 最大字典序排列(树状数组)

    51Node  1364--- 最大字典序排列(树状数组) 1364 最大字典序排列 基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题  收藏  关注 给出一个1至N ...

  3. 51nod 1364 最大字典序排列&lpar;线段树&rpar;

    1364 最大字典序排列基准时间限制:1 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 给出一个1至N的排列,允许你做不超过K次操作,每次操作可以将相邻的两个数交换,问能够得到的字 ...

  4. &lbrack;Swift-2019力扣杯春季决赛&rsqb;2&period; 按字典序排列最小的等效字符串

    给出长度相同的两个字符串:A 和 B,其中 A[i] 和 B[i] 是一组等价字符.举个例子,如果 A = "abc" 且 B = "cde",那么就有 'a' ...

  5. &lbrack;leetcode&rsqb;&lpar;4&period;21&rpar;2&period; 按字典序排列最小的等效字符串

    给出长度相同的两个字符串:A 和 B,其中 A[i] 和 B[i] 是一组等价字符.举个例子,如果 A = "abc" 且 B = "cde",那么就有 'a' ...

  6. hdu1027&lpar;n个数的按字典序排列的第m个序列&rpar;

    题目信息:给出n.m,求n个数的按字典序排列的第m个序列 http://acm.hdu.edu.cn/showproblem.php? pid=1027 AC代码: /**  *全排列的个数(次序) ...

  7. poj 1146 ID Codes &lpar;字符串处理 生成排列组合 生成当前串的下一个字典序排列 【&ast;模板】 &rpar;

    ID Codes Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 6229   Accepted: 3737 Descript ...

  8. 46&period; 47&period; Permutations and Permutations II 都适用(Java,字典序 &plus; 非字典序排列)

    解析: 一:非字典序(回溯法) 1)将第一个元素依次与所有元素进行交换: 2)交换后,可看作两部分:第一个元素及其后面的元素: 3)后面的元素又可以看作一个待排列的数组,递归,当剩余的部分只剩一个元素 ...

  9. POJ-1318(list&period;sort&lpar;&rpar;输出不为字典序,map才是按字典序排列)

    #include<iostream> #include<string> #include<list> #include<map> #include&lt ...

随机推荐

  1. &lbrack;转载&rsqb;我的WCF之旅(1):创建一个简单的WCF程序

    为了使读者对基于WCF的编程模型有一个直观的映像,我将带领读者一步一步地创建一个完整的WCF应用.本应用功能虽然简单,但它涵盖了一个完整WCF应用的基本结构.对那些对WCF不是很了解的读者来说,这个例 ...

  2. 如何用Linux的命令正确识别cpu的个数和核数【转】

    判断依据: 1.具有相同core id的cpu是同一个core的超线程. 2.具有相同physical id的cpu是同一颗cpu封装的线程或者cores. 英文版: 1.Physical id an ...

  3. ubuntu14&period;04美化

    首先我美化grub启动菜单背景和开关机背景,还有自动换壁纸.其它的美化日后再写博文. Grub启动菜单背景更换: 这个很简单,比以前的ubuntu和grub版本简单多了,直接将图片文件放到/boot/ ...

  4. swift-02代码流程的控制

    // //  main.swift //  02-语句 // //  Created by wanghy on 15/8/9. //  Copyright (c) 2015年 wanghy. All ...

  5. GMA Round 1 新程序

    传送门 新程序 程序框图如图所示,当输入的n=时,输出结果的ans是多少? 容易看出该程序求n以内质数个数,50以内有15个. 定位:简单题

  6. 征服诱人的Vagrant!

    一.背景 ​ 最近要开始深入学习分布式相关的东西了,那第一步就是在自己的电脑上安装虚拟机,以前在Windows平台,我选择用VMware Workstation作为虚拟机软件,现在在Mac系统下,感觉 ...

  7. python 全栈开发,Day66&lpar;web应用&comma;http协议简介&comma;web框架&rpar;

    一.web应用 web应用程序是一种可以通过Web访问的应用程序,程序的最大好处是用户很容易访问应用程序,用户只需要有浏览器即可,不需要再安装其他软件.应用程序有两种模式C/S.B/S.C/S是客户端 ...

  8. Leetcode题库——46&period;全排列

    @author: ZZQ @software: PyCharm @file: permute.py @time: 2018/11/15 19:42 要求:给定一个没有重复数字的序列,返回其所有可能的全 ...

  9. 贝壳找房魔法师顾问&lbrack;并查集&plus;DAG判断&rsqb;

    题目链接[https://nanti.jisuanke.com/t/27647] //计蒜客2018复赛D题,想简单了. 题解: 题目是中文的,不再赘述. 题解: 分为三种情况:1.两个字符串都不能变 ...

  10. 万网上如何将IP和申请的域名绑定

    万网上如何将IP和申请的域名绑定   在万网上购买了域名后,怎么将它和指定的IP进行绑定呢?下面简单介绍下 工具/原料   中国万网账号 购买的域名 服务器 方法/步骤     百度万网,找到网站后, ...