洛谷 P1160 队列安排
题目描述
一个学校里老师要将班上 NNN 个同学排成一列,同学被编号为 $1~N$ ,他采取如下的方法:
先将 111 号同学安排进队列,这时队列中只有他一个人;
2−N2-N2−N 号同学依次入列,编号为i的同学入列方式为:老师指定编号为i的同学站在编号为 1−(i−1)1-(i -1)1−(i−1) 中某位同学(即之前已经入列的同学)的左边或右边;
3.从队列中去掉 M(M<N)M(M<N)M(M<N) 个同学,其他同学位置顺序不变。
在所有同学按照上述方法队列排列完毕后,老师想知道从左到右所有同学的编号。
输入输出格式
输入格式:
第 111 行为一个正整数 NNN ,表示了有 NNN 个同学。
第 2−N2-N2−N 行,第 iii 行包含两个整数 k,pk,pk,p ,其中 kkk 为小于 iii 的正整数, ppp 为 000 或者 111 。若 ppp 为 000 ,则表示将 iii 号同学插入到 kkk 号同学的左边, ppp 为 111 则表示插入到右边。
第 N+1N+1N+1 行为一个正整数 MMM ,表示去掉的同学数目。
接下来 MMM 行,每行一个正整数 xxx ,表示将 xxx 号同学从队列中移去,如果 xxx 号同学已经不在队列中则忽略这一条指令。
输出格式:
111 行,包含最多 NNN 个空格隔开的正整数,表示了队列从左到右所有同学的编号,行末换行且无空格。
输入输出样例
说明
样例解释:
将同学 222 插入至同学 111 左边,此时队列为:
212 121
将同学 333 插入至同学 222 右边,此时队列为:
2312 3 1231
将同学 444 插入至同学 111 左边,此时队列为:
23412 3 4 12341
将同学 333 从队列中移出,此时队列为:
2412 4 1241
同学 333 已经不在队列中,忽略最后一条指令
最终队列:
2412 4 1241
数据范围
对于 20%20\%20% 的数据,有 N≤10N≤10N≤10 ;
对于 40%40\%40% 的数据,有 N≤1000N≤1000N≤1000 ;
对于 100%100\%100% 的数据,有 N,M≤100000N, M≤100000N,M≤100000 。
就是一个基础链表,挺简单的。
#include<iostream>
#include<cstdio>
using namespace std;
const int N=;
int n,m;
bool b[N];
struct node
{
int l,r;
}a[N];
void ins(int x,int y,int d)
{
if(d==)
a[x].l=a[y].l,a[x].r=y,a[a[y].l].r=x,a[y].l=x;
else
a[x].r=a[y].r,a[x].l=y,a[a[y].r].l=x,a[y].r=x;
}
int main()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
a[i].l=a[i].r=-;
a[].l=,a[].r=n+;
for(int i=;i<=n;i++)
{
int k,p;
scanf("%d%d",&k,&p);
ins(i,k,p);
}
scanf("%d",&m);
while(m--)
{
int x;
scanf("%d",&x);
if(!b[x])
{
b[x]=;
a[a[x].l].r=a[x].r;
a[a[x].r].l=a[x].l;
a[x].l=a[x].r=-;
}
}
for(int i=;i<=n;i++)
if(!b[i]&&a[i].l==)
{
int t=i;
printf("%d ",t);
while(a[t].r!=n+)
{
t=a[t].r;
printf("%d ",t);
}
printf("\n");
}
return ;
}
洛谷 P1160 队列安排的更多相关文章
- 洛谷 P1160 队列安排 Label:链表 数据结构
题目描述 一个学校里老师要将班上N个同学排成一列,同学被编号为1-N,他采取如下的方法: 1.先将1号同学安排进队列,这时队列中只有他一个人: 2.2-N号同学依次入列,编号为i的同学入列方式为:老师 ...
- 洛谷P1160 队列安排
题目描述 一个学校里老师要将班上N个同学排成一列,同学被编号为1-N,他采取如下的方法: 1.先将1号同学安排进队列,这时队列中只有他一个人: 2.2-N号同学依次入列,编号为i的同学入列方式为:老师 ...
- 洛谷P1160——队列安排(双向链表)
题目描述 一个学校里老师要将班上N个同学排成一列,同学被编号为1-N,他采取如下的方法: 1.先将1号同学安排进队列,这时队列中只有他一个人: 2.2-N号同学依次入列,编号为i的同学入列方式为:老师 ...
- 洛谷——P1160 队列安排(链表的基础操作)
#include<bits/stdc++.h> using namespace std; ]; list<int> stus; list<];//用来存放每一项的迭代器 ...
- luogu P1160 队列安排
二次联通门 :luogu P1160 队列安排 /* luogu P1160 队列安排 链表 手动模拟一下就好了... */ #include <cstdio> #define Max 5 ...
- AC日记——队列安排 洛谷 P1160
队列安排 思路: 链表裸题: 来,上代码: #include <cstdio> #include <cstring> #include <iostream> usi ...
- 队列 P1160 队列安排(啊啊 不会啊)
洛谷 题目描述 一个学校里老师要将班上N个同学排成一列,同学被编号为1-N,他采取如下的方法: 1.先将1号同学安排进队列,这时队列中只有他一个人: 2.2-N号同学依次入列,编号为i的同学入列方式为 ...
- [洛谷P2365] 任务安排
洛谷题目链接:任务安排 题目描述 N个任务排成一个序列在一台机器上等待完成(顺序不得改变),这N个任务被分成若干批,每批包含相邻的若干任务.从时刻0开始,这些任务被分批加工,第i个任务单独完成所需的时 ...
- 洛谷P2365 任务安排(斜率优化dp)
传送门 思路: 最朴素的dp式子很好考虑:设\(dp(i,j)\)表示前\(i\)个任务,共\(j\)批的最小代价. 那么转移方程就有: \[ dp(i,j)=min\{dp(k,j-1)+(sumT ...
随机推荐
- Hadoop Yarn调度器的选择和使用
一.引言 Yarn在Hadoop的生态系统中担任了资源管理和任务调度的角色.在讨论其构造器之前先简单了解一下Yarn的架构. 上图是Yarn的基本架构,其中ResourceManager是整个架构的核 ...
- ZOJ - 2423-Fractal
A fractal is an object or quantity that displays self-similarity, in a somewhat technical sense, on ...
- java redis 分页查询数据
package com.liying.tiger.test; import java.util.List; import org.springframework.context.Application ...
- java 日志框架总结
在项目开发过程中,我们可以通过 debug 查找问题.而在线上环境我们查找问题只能通过打印日志的方式查找问题.因此对于一个项目而言,日志记录是一个非常重要的问题.因此,如何选择一个合适的日志记录框架也 ...
- Item 13: 比起iterator优先使用const_iterator
本文翻译自modern effective C++,由于水平有限,故无法保证翻译完全正确,欢迎指出错误.谢谢! 博客已经迁移到这里啦 STL中的const_iterator等价于pointers-to ...
- webpack打包经验——处理打包文件体积过大的问题
前言 最近对一个比较老的公司项目做了一次优化,处理的主要是webpack打包文件体积过大的问题. 这里就写一下对于webpack打包优化的一些经验. 主要分为以下几个方面: 去掉开发环境下的配置 Ex ...
- 使用go mod结合docker分层缓存进行自动CI/CD
本文地址:https://www.cnblogs.com/likeli/p/10521941.html 喜大奔的go mod 官方背书的go mod拯救了我的代码洁癖症! 环境 go v1.12 do ...
- WEB学习感受
web学习感受 1.html前端知识比较好学,各种标签只需要记住关键的就行例如:body h1,p,div,tr,td,ul,li,就行了. 2.css学习前期还好, 后期关键布局和样式知识点较多,而 ...
- 二、截取字符串长度(css方式)
只针对谷歌 width: 100%; //height: 58px; overflow:hidden; text-overflow:ellipsis; display: -webkit-box; -w ...
- python的四种内置数据结构
对于每种编程语言一般都会规定一些容器来保存某些数据,就像java的集合和数组一样python也同样有这样的结构 而对于python他有四个这样的内置容器来存储数据,他们都是python语言的一部分可以 ...