news 2026/4/20 15:26:57

洛谷 P1160:队列安排 ← 数组模拟

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
洛谷 P1160:队列安排 ← 数组模拟

【题目来源】
https://www.luogu.com.cn/problem/P1160

【题目描述】
一个学校里老师要将班上 N 个同学排成一列,同学被编号为 1∼N,他采取如下的方法:
(1)先将 1 号同学安排进队列,这时队列中只有他一个人;
(2)2∼N 号同学依次入列,编号为 i 的同学入列方式为:老师指定编号为 i 的同学站在编号为 1∼(i−1) 中某位同学(即之前已经入列的同学)的左边或右边;
(3)从队列中去掉 M 个同学,其他同学位置顺序不变。
在所有同学按照上述方法队列排列完毕后,老师想知道从左到右所有同学的编号。

【输入格式】
第一行一个整数 N,表示了有 N 个同学。
第 2∼N 行,第 i 行包含两个整数 k,p,其中 k 为小于 i 的正整数,p 为 0 或者 1。若 p 为 0,则表示将 i 号同学插入到 k 号同学的左边,p 为 1 则表示插入到右边。
第 N+1 行为一个整数 M,表示去掉的同学数目。
接下来 M 行,每行一个正整数 x,表示将 x 号同学从队列中移去,如果 x 号同学已经不在队列中则忽略这一条指令。

【输出格式】
一行,包含最多 N 个空格隔开的整数,表示了队列从左到右所有同学的编号。

【输入样例】
4
1 0
2 1
1 0
2
3
3

【输出样例】
2 4 1

【数据范围】
对于 20% 的数据,1≤N≤10。
对于 40% 的数据,1≤N≤1000。
对于 100% 的数据,1<M≤N≤10^5。

【算法分析】
● 本题利用
数组模拟实现双链表的代码思想,与“AcWing 827:双链表”的思想基本一致。详见:https://blog.csdn.net/hnjzsyjyj/article/details/150845789

● 本题利用数组模拟实现双链表的示意图,附设了 idx=0 及 idx=1 两个结点。之后,插入结点 2(idx=2)的示意图如下所示。

● 特别要注意,本题在删除某个结点时,要进行特判,看看待删结点是否还存在。若不存在,忽略此删除操作。

● 本题用
STL list实现的代码,详见:https://blog.csdn.net/hnjzsyjyj/article/details/151970421

【算法代码】

#include <bits/stdc++.h> using namespace std; const int maxn=1e5+5; int le[maxn],ri[maxn],v[maxn],idx; bool st[maxn]; int n,m,k,q,x; void init() { ri[0]=1,le[1]=0; idx=2; } void insert(int p,int x) { v[idx]=x; le[idx]=p,ri[idx]=ri[p]; le[ri[p]]=idx,ri[p]=idx++; } void remove(int k) { ri[le[k]]=ri[k]; le[ri[k]]=le[k]; } int main() { init(); insert(0,1); cin>>n; for(int i=2; i<=n; i++) { cin>>k>>q; if(q) insert(k+1,i); else insert(le[k+1],i); } cin>>m; while(m--) { cin>>x; if(!st[x]) { remove(x+1); st[x]=true; } } for(int i=ri[0]; i!=1; i=ri[i]) { cout<<v[i]<<" "; } return 0; } /* in: 4 1 0 2 1 1 0 2 3 3 out: 2 4 1 */




【参考文献】
https://blog.csdn.net/hnjzsyjyj/article/details/150845789
https://blog.csdn.net/hnjzsyjyj/article/details/151970421
https://www.luogu.com.cn/problem/solution/P1160
https://blog.csdn.net/lq1990717/article/details/127429719




版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 19:07:29

AI语音新选择:Qwen3-TTS多语言合成体验

AI语音新选择&#xff1a;Qwen3-TTS多语言合成体验 1. 引言 语音合成技术正在经历一场革命性的变革。从早期机械式的电子语音&#xff0c;到如今近乎真人般自然的语音合成&#xff0c;TTS&#xff08;Text-to-Speech&#xff09;技术已经深入到我们生活的方方面面。无论是智能…

作者头像 李华
网站建设 2026/4/18 5:10:02

医疗AI新选择:MedGemma医学影像分析系统初探

医疗AI新选择&#xff1a;MedGemma医学影像分析系统初探 关键词&#xff1a;MedGemma、医学影像分析、多模态大模型、AI医疗、影像解读 摘要&#xff1a;想象一下&#xff0c;医生在分析CT影像时&#xff0c;能像聊天一样向AI提问&#xff1a;“这片区域有什么异常&#xff1f;…

作者头像 李华
网站建设 2026/4/19 2:51:43

一键转换!深求·墨鉴将图片文字变可编辑文本

一键转换&#xff01;深求墨鉴将图片文字变可编辑文本 你是否曾面对一堆纸质文件、扫描的PDF或手机拍摄的笔记照片&#xff0c;为了一字一句地敲进电脑而头疼&#xff1f;或者&#xff0c;在整理会议纪要、归档学术资料时&#xff0c;被繁琐的复制粘贴工作消耗了大量精力&…

作者头像 李华
网站建设 2026/4/16 16:20:44

Fish Speech 1.5开箱即用:无需配置的语音合成方案

Fish Speech 1.5开箱即用&#xff1a;无需配置的语音合成方案 你是否曾经为了给视频配音、制作有声内容或者开发语音应用而头疼&#xff1f;传统的语音合成工具要么需要复杂的配置&#xff0c;要么效果不够自然&#xff0c;要么价格昂贵。现在&#xff0c;有了Fish Speech 1.5…

作者头像 李华
网站建设 2026/4/20 15:00:21

3步搞定:BEYOND REALITY Z-Image快速生成商业级人像

3步搞定&#xff1a;BEYOND REALITY Z-Image快速生成商业级人像 在电商、广告、社交媒体内容创作等领域&#xff0c;高质量的商业级人像图片需求巨大。传统摄影成本高昂、周期长&#xff0c;而普通AI生成的人像又常常面临“塑料感”重、细节模糊、光影不自然等问题&#xff0c…

作者头像 李华