牛客网——简单排序(lower_bound( ))

探讨使用最少数量的先进先出队列,将乱序序列复原为降序的问题。通过C++代码示例,解析算法思路,适用于竞赛及算法优化场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

链接:https://ac.nowcoder.com/acm/contest/547/F
来源:牛客网
 

题目描述

LXK有一个序列,从N~1,但是他不小心把序列打乱了,现在他想找你把这串序列复原。

他讨厌用传统的方式排序。所以他用他自己的方式进行复原。

他有K个先进先出的队列

对于某个数字,你可以选择将其放入任意队列之中(不能不放)。

每个队列中队首的数字可以在任意时间出队列。

利用这些队列,聪明的LXK就可以将序列复原回降序。

他想知道这些操作最少需要准备多少个队列?    

 

输入描述:

一个数N(N<100000)

表示数字的数目

接下来一行 n个数字

输出描述:

一个数k

表示最少需要多少个队列才能满足要求

示例1

输入

复制

5
1 2 3 4 5

输出

复制

5

示例2

输入

复制

7
1 2 5 7 3 4 6

输出

复制

5
#include<iostream>
using namespace std;
int main(){
	int n,len=0,a[100005],x;
	cin>>n;
	for(int i=0;i<n;i++){
		cin>>x;
		int tmp=lower_bound(a,a+len,x)-a;
		if(tmp<len)
	    	a[tmp]=x;
	    else{
	        a[len]=x;
	        len++;	    	
		}
	}
	cout<<len<<endl;
	return 0;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值