为荣誉而拼搏少年 2024-04-25 19:56 采纳率: 36.8%
浏览 19
已结题

1287. 【2017年常州市】小X与队列 (queue)

  1. 【2017年常州市】小X与队列 (queue)
    (Input: queue.in, Output: queue.out)
    时间限制: 1 s 空间限制: 256 MB 具体限制

题目描述
 小X正和同学们做列队的练习。
  有n名同学排成一路纵队,编号为i的同学排在从前往后数第i个位置上,即:初始时的队列为1, 2, 3, ..., n。
  接下来小X会发出若干条指令,每条指令形如“请编号为x的同学排到最前面来”。(例如:若当前时刻的队列为5, 4, 3, 2, 1,发出一条x=2的指令后,队列变成了2, 5, 4, 3, 1。)
  小X发出了很多很多指令,同学们晕头转向不知道该怎么排列。于是就请你算一算,执行完这些指令后,队列应该变成什么样?

输入
从文件 queue.in 中读入数据。

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

输出
输出到文件 queue.out 中。

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

样例输入 复制
4 3
2 3 2

样例输出 复制
2 3 1 4

数据范围限制
对于30%的数据,1<=n,m<=1000
对于另外30%的数据,n=m,且1~n每个数在x[i]中恰好出现一次。
对于100%的数据,1<=n,m<=100000

提示
样例解释
  第一条指令前:1 2 3 4
  第一条指令后(x=2):2 1 3 4
  第二条指令后(x=3):3 2 1 4
  第三条指令后(x=2):2 3 1 4

  • 写回答

5条回答 默认 最新

  • aaahhg 2025-02-15 12:59
    关注
    
    #include<bits/stdc++.h>
    using namespace std;
     
    bool c[10000100];
    
    int main(){
        deque <int> q; 
        int m,n;
        cin>>m>>n;
        for(int i=1;i<=m;i++)
        {
            q.push_back(i);
            
        }
        int sr;
        for(int i=1;i<=n;i++)
        {
            cin>>sr;
            q.push_front(sr);
        }
        for(int i=0;i<q.size();i++)
        {
            if(c[q[i]]==0)
            {
                cout<<q[i]<<" ";
                c[q[i]]=1;
                
            }
        }
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 3月2日
  • 已采纳回答 3月2日
  • 创建了问题 4月25日