zoukankan      html  css  js  c++  java
  • 山东财经大学新生赛暨天梯赛选拔赛 F 简单排序(队列的基本运用)

    链接: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>
    #include<cstring>
    #include<string>
    #include<algorithm>
    using namespace std;
    
    int a[100000+10],b[100000+10];
    int main()
    {
    	int n,m,j,k,i,T;
    	cin>>n;
    	for (i=0;i<n;i++)
    	cin>>a[i];
    	
    	int sum=1;
    	j=0;
    	b[j++]=a[0];
    	for (i=1;i<n;i++)
    	{
    		bool flag=false;
    		for (k=0;k<j;k++)
    		{
    			if (a[i]<=b[k])
    			{
    				b[k]=a[i];
    				flag=true;
    				break;
    			}
    		}
    		if (flag==false)
    		{
    			b[j++] = a[i];
    			sum++;
    		}
    		
    	}
    	cout<<sum<<endl;
    	return 0;
    }
  • 相关阅读:
    Windows安全应急响应(一)
    net.exe和net1.exe的区别&联系.
    IIS搭建ASP站点
    在linux中安装VM tools
    第十五章 特殊权限
    第十四章 权限管理
    第十三章 用户组与提权
    第十一章 用户的创建
    第十章 组的创建
    第八章 vim 编辑器
  • 原文地址:https://www.cnblogs.com/Romantic-Chopin/p/12451089.html
Copyright © 2011-2022 走看看