2897: 【基础】小X与队列

题目:

时间限制 : 1 Sec

内存限制 : 128 Mb

提交 : 125

解决 : 65

题目描述

小X正和同学们做列队的练习。

有n名同学排成一路纵队,编号为i的同学排在从前往后数第i个位置上,即:初始时的队列为1, 2, 3, ..., n。

接下来小X会发出若干条指令,每条指令形如“请编号为x的同学排到最前面来”。(例如:若当前时刻的队列为5, 4, 3, 2, 1,发出一条x=2的指令后,队列变成了2, 5, 4, 3, 1。)

小X发出了很多很多指令,同学们晕头转向不知道该怎么排列。于是就请你算一算,执行完这些指令后,队列应该变成什么样?

输入

第一行两个用空格隔开的正整数n和m,分别表示人数和指令数。

第二行m个用空格隔开的正整数x[i],按顺序表示每次指令的x值。

输出

输出仅有一行包含n个正整数,相邻两个数之间用一个空格隔开,表示执行完所有指令后的队列。

样例输入

4 3 2 3 2

样例输入

2 3 1 4

样例解释

第一条指令前:1 2 3 4

第一条指令后(x=2):2 1 3 4

第二条指令后(x=3):3 2 1 4

第三条指令后(x=2):2 3 1 4

数据范围

对于30%的数据,1<=n,m<=1000

对于另外30%的数据,n=m,且1~n每个数在x[i]中恰好出现一次。

对于100%的数据,1<=n,m<=100000

思路:

标程:

#include<bits/stdc++.h>
using namespace std;
int n,m,an,ha[100001],a[100000],c[100001];
int main()
{
    scanf("%d%d",&m,&n);
    for (int i=1;i<=n;i++)
    {
        scanf("%d",&c[i]);
    }
    for (int i=n;i>=1;i--)
    {
        if (ha[c[i]]==0)
        {
            an++;
            a[an]=c[i];
            ha[c[i]]=1;
        }
    }
    cout<<a[1];
    for (int i=2;i<=an;i++)
    {
        cout<<" "<<a[i];
    }
    for (int i=1;i<=m;i++)
    {
        if (ha[i]==0)
        {
            cout<<" "<<i;
        }
    }
cout<<endl;
return 0;
}

时间: 2024-08-10 15:14:34

2897: 【基础】小X与队列的相关文章

Linux基础小模块

1.基础知识小块:shell 由shell程序的自带命令:即为内置命令(builtin) 独立的可执行程序文件.文件名 :即为外部命令 [[email protected]~]#ls      ~用户当前所在目录  #:命令提示符(管理员帐号root)  $:普通用户          | shell环境 | 独特程序  它是指操作系统中,提供访问内核所提供之服务的程序!系统跟计算机硬件交互时使用的中间介质,负责解析用户提供的命令. 2.基础小知识:命令 #echo $PATH :从那些路径中查

JavaScript基础--小案例:在网页指定位置弹出错误信息(十二)

案例分析:点击按钮后,在网页上指定区域,提示错误信息!5秒后,错误信息提示自动消失! 1 <script languag="javascript" type="text/javascript"> 2 var clearId; 3 function test(){ 4 document.getElementById("showMsg").style.cssText="width:200px;height:50px;left:6

Windbg CLR基础小测 《第六篇》

首先写一段代码如下: namespace ConsoleApplication3 { class Program { static void Main(string[] args) { Console.WriteLine("Hello, Windbg!"); Console.ReadKey(); } } } 在Debug目录中启动该程序,然后在Debug中附加该进程. 0:007> .load C:/WINDOWS/Microsoft.NET/Framework/v4.0.303

Photoshop基础 小问答

1. 如何快速把转斜的图片水平摆正? 答:点 吸管工具 - 度量工具,在图片中找2个水平的点(这2个点是图片内物体的水平,不是图片的水平),然后点  图像 - 旋转画布 - 任意角度,OK! 2. 因相机斜拍,造成图片视角倾斜,有什么办法摆正?答:点 编辑 - 变换 - 扭曲,在倾斜的角点住左键,慢慢可拉正图片,直到效果看来成正面水平,OK! 3. CMYK怎么转RGB图像模式?答:点 图像 - 模式 - RGB模式,OK! 4. 有些图片打开横或竖有条绿线,操作没影响,删又删不掉,怎么办?答:

ios基础-小知识点收集(1)

不积跬步,无以至千里;不积小流,无以成江海.----荀子 收集学习ios中的小知识点,每天进步一点点. (一)@class和 #import class:只声明类,不会引入类文件,加快编译速度,防止类相互import出错:在m中仍然需要import整个类文件. import导入整个类文件,在需要使用类中的变量.函数和协议的时候需要使用. (二)静态变量static.全局变量extern.局部变量.实例变量 static:为整类而非单个对象使用,隐藏封装在类中,对外不可见. 静态变量的优点: 1.

iOS多线程开发小demo7 GCD队列组

// DYFViewController.m // 623-08-队列组 // // Created by dyf on 14-6-23. // Copyright (c) 2014年 ___FULLUSERNAME___. All rights reserved. // #import "DYFViewController.h" @interface DYFViewController () @property (weak, nonatomic) IBOutlet UIImageVi

没有基础小编带你,用python画机器猫(有代码)

小编带你玩python 没有基础小编带你,用python画机器猫.只需要python3和小编的代码即可.python3小编送,代码文章有,现在就差个你了. 运行不了的找小编,小编包教会你. 重要的事情说三遍: python3小编送,代码文章有. python3小编送,代码文章有. python3小编送,代码文章有. 运行不了的找小编,加Q君羊 八八三四四四一零六. 君羊里的小伙伴和管理员的会这个运行这个源代码.需要学习视频的直接找管理员要,就说是小编让的,烦死她.欢迎小伙伴的加入. 原文地址:h

shell脚本基础小习题(二)

shell脚本基础小习题(二) 编写一个memusage.sh,根据Free命令的结果计算出内存占用率 思路: 1:在屏幕输出"free"先查看命令结果 2:根据给出的结果我们需要用到"total"和"free" total:列显示系统总的可用物理内存和交换空间大小. free:列显示还有多少物理内存和交换空间可用使用. 这里我们只看Mem(内存的使用情况)就可以. 3:我们创建脚本但是我们在free的Mem中只需要用("total&q

基础小知识,持续更新中~

一.一些基础小命令 dir = 查看当前目录文件列表 cd .. 返回上一层目录 cd ../.. 返回上上一层目录 二.关于中文编码 #-*- coding:utf-8 -*-print ("中国") 三.设置notepad++ 快捷键 设置--->首选项--->语言---->勾选替换为空格,tab键自动打印4个空格 视图--->显示符号--->显示空格与制表符. 四.注释 # 单行注释'''多行注释'''""" 多行注释