首页 > 其他分享 >列表--list容器的使用(STL熟练掌握)

列表--list容器的使用(STL熟练掌握)

时间:2022-10-26 20:00:12浏览次数:101  
标签:同学 11 队列 正整数 -- list Pos STL int


题目描述

一个学校里老师要将班上NN个同学排成一列,同学被编号为1\sim N1∼N,他采取如下的方法:

  1. 先将11号同学安排进队列,这时队列中只有他一个人;
  2. 2-N2−N号同学依次入列,编号为i的同学入列方式为:老师指定编号为i的同学站在编号为1\sim (i -1)1∼(i−1)中某位同学(即之前已经入列的同学)的左边或右边;
  3. 从队列中去掉M(M<N)M(M<N)个同学,其他同学位置顺序不变。

在所有同学按照上述方法队列排列完毕后,老师想知道从左到右所有同学的编号。

输入格式

第11行为一个正整数NN,表示了有NN个同学。

第2-N2−N行,第ii行包含两个整数k,pk,p,其中kk为小于ii的正整数,pp为00或者11。若pp为00,则表示将ii号同学插入到kk号同学的左边,pp为11则表示插入到右边。

第N+1N+1行为一个正整数MM,表示去掉的同学数目。

接下来MM行,每行一个正整数xx,表示将xx号同学从队列中移去,如果xx号同学已经不在队列中则忽略这一条指令。

输出格式

11行,包含最多NN个空格隔开的正整数,表示了队列从左到右所有同学的编号,行末换行且无空格。

输入输出样例

输入 #1复制


4 1 0 2 1 1 0 2 3 3


输出 #1复制


2 4 1


说明/提示

样例解释:

将同学22插入至同学11左边,此时队列为:

2 121

将同学33插入至同学22右边,此时队列为:

2 3 1231

将同学44插入至同学11左边,此时队列为:

2 3 4 12341

将同学33从队列中移出,此时队列为:

2 4 1241

同学33已经不在队列中,忽略最后一条指令

最终队列:

2 4 1241

数据范围

对于20\%20%的数据,有N≤10N≤10;

对于40\%40%的数据,有N≤1000N≤1000;

对于100\%100%的数据,有N, M≤100000N,M≤100000。

#include<iostream>
#include<list>

using namespace std;
using Iter = list<int>::iterator;

int N,M;
Iter Pos[100005];
list<int> l;
bool HasBeErased[100005];

int main() {
scanf("%d", &N);
l.push_front(1);
Pos[1] = l.begin();
for (int i = 2; i <= N; i++) {
int k, p;
scanf("%d%d", &k, &p);
if (p == 0) {
Pos[i] = l.insert(Pos[k], i);
}
else {
Pos[i] = l.insert(next(Pos[k]), i);
}
}
scanf("%d", &M);
for (int i = 1; i <= M; i++) {
int x;
scanf("%d", &x);
if (!HasBeErased[x]) {
l.erase(Pos[x]);
}
HasBeErased[x] = true;
}
bool First = true;
for (int x : l) {
if (First) {
printf("%d", x);
First = false;
}
else {
printf(" %d", x);
}
}
return 0;
}

 

标签:同学,11,队列,正整数,--,list,Pos,STL,int
From: https://blog.51cto.com/u_13121994/5798312

相关文章

  • .Net内置JSON序列化中文问题
    今天在用System.Text.Json序列化的时候遇到了中文序列化的一个问题,示例如下:JsonSerializer.Serialize(new{Name="你好"});预期结果是:{"Name":"你好"},但得到结果如下......
  • 洛谷 P7003
    考虑当左端点固定时,区间的\(\&\)和至多有\(\logw\)种,因为\(1\)的数量是单调不升的。所以我们可以枚举区间左端点\(i\),然后ST表预处理区间\(\&\)和+二分求出......
  • 李超线段树 学习笔记
    李超线段树学习笔记引入最近一直在做斜率优化的题,然而只会傻傻维护凸包,一到横坐标不单调,就涉及到手打平衡树,但是我实在不想学平衡树了,所以就准备掏出解决处理直线的大宝......
  • Do whlie 循环
    Dowhlie循环◆对于while语句而言,如果不满足条件,则不能进入循环。但有时候我们需要即使不满足条件,也至少执行-次。◆do...while循环和while循环相似,不同的是,do...whi......
  • AutoMapper在.Net Core WebApi中使用
    在.NetCoreWebApi里使用AutoMapper1.安装AutoMapper管理包 注意:service层中安装WebApi层也需要安装因为Webpi层有时候也需要用到Dto 2.startup在Configure......
  • CMakeList之macro
    一、定义1、可以把它理解为C++的宏,命令如下macro(<name>[<arg1>...])<commands>endmacro()定义一个名为的宏,它接受名为,…等一系列的参数。macro与endmacro之间列......
  • 【idea技巧】scratches file的使用
    在使用idea时候,url的左边有个小地球点击可以创建相应的地址,在idea本地可以测试url,不必打开网页......
  • 虚树
    虚树我们有这样一类问题,对于一个有\(n\)个点的树,有\(m\)组询问,每次询问给出\(k\)个关键点,关键点之间的最短距离。其中\(\sumk\len,n\le1e5\)。我们发现这一类......
  • 爬虫、openpyxl、pandas
    目录今日内容概要今日内容详细作业详解第三方模块的下载与使用网络爬虫模块之requests模块网络爬虫实战之爬取链家二手房数据自动化办公领域之openpyxl模块homework今日内......
  • requests模块和openpyxl模块
    第三方模块的下载和使用1,第三方模块就是别人大神们已经写好的模块,功能特别强大。我们如果像使用第三方模块就先要进行下载。下载完成后才可以在python中直接调用2.下......