P1162 列车编组问题

2024-02-26 05:04
文章标签 问题 p1162 列车 编组

本文主要是介绍P1162 列车编组问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

P1162 列车编组问题

  • 一、原题呈现
    • 1、题目描述
    • 2、输入描述
    • 3、输出描述
    • 4、样例输入
    • 5、样例输出
  • 二、思路分析
    • 1、思想转化
    • 2、用数组构建栈的思想
    • 3、分析情况
  • 三、整体代码

一、原题呈现

1、题目描述

某火车站铁轨铺设如图,有 n 节车厢自 A 方向进入车站,按进站方向编号为 1 ~ n。现对其进行
编组,编组过程可借助中转站 Station,其中 Station 可停靠任意多车厢,由于 Station 末端封
顶,故驶入 Station 的车辆必须按相反方向驶出。对每个车厢,一旦自 A 进入 Station,就不能
再驶入 A;且一旦自 Station 驶入 B,再不能返回 Station。给定 n 值,请判断某个车厢编组是
否可能。

2、输入描述

有多组输入,每组输入占两行。
第一行是车厢节数 n,第二行是 1, 2, ..., n 的一个排列。

3、输出描述

针对每种出站方案,输出该方案是否可行的判断结果。

4、样例输入

5
1 2 3 4 5
5
5 4 1 2 3
6
6 5 4 3 2 1

5、样例输出

Yes
No
Yes

二、思路分析

1、思想转化

本题其实就是栈的应用,Station就是栈
对于所谓不需要进入Station的,可以理解为进入Station后立刻出去
然后判断给出的出栈结果是否有对应的入栈出栈方案

2、用数组构建栈的思想

// 内容		数组/变量	示例		遍历下标	
// 出站方案 station 		1 2 3 4 5 	i
// 火车 	train		1 2 3 4 5	train 
// 临存 	re						loc
// temp为标记位,是否可以有对应出栈方案
int i, j, re[11000] = {0}, station[11000] = {0}, temp = 1, train = 1, loc = 1;
//输入
for(i = 0; i < n; i++)cin>>station[i];
// 第一辆车默认进站
i = 0, re[1] = 1;

3、分析情况

// 车全部进出结束
while(i <= n) {// 此时栈中的火车编号和需要的列车编号相同if(station[i] == re[loc])// 火车出栈,需求的火车数组下标+1i++, loc--;// 因为进栈编号永远是越来越大,所以当需求的火车编号比栈顶火车编号大的时候,说明需要的火车还在后面,那就将火车继续进栈else if(station[i] > re[loc])re[++loc] = ++train;// 否则此时需要的火车在栈里,但不在栈顶,无法出栈,因此为falseelse {temp = 0;break;}
}

三、整体代码

#include<bits/stdc++.h> using namespace std;int main() {int n;while(cin>>n) {int i, j, re[11000] = {0}, station[11000] = {0}, temp = 1, train = 1, loc = 1;for(i = 0; i < n; i++)cin>>station[i];i = 0, re[1] = 1;// 出站方案 station 1 2 3 4 5 	i// 火车 	train	1 2 3 4 5	train // 临存 	re					locwhile(i <= n) {if(station[i] == re[loc])i++, loc--;else if(station[i] > re[loc])re[++loc] = ++train;else {temp = 0;break;}}if(temp)cout<<"Yes"<<endl;elsecout<<"No"<<endl;}return 0;
}

这篇关于P1162 列车编组问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/747771

相关文章

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

idea npm install很慢问题及解决(nodejs)

《ideanpminstall很慢问题及解决(nodejs)》npm安装速度慢可通过配置国内镜像源(如淘宝)、清理缓存及切换工具解决,建议设置全局镜像(npmconfigsetregistryht... 目录idea npm install很慢(nodejs)配置国内镜像源清理缓存总结idea npm in

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

idea突然报错Malformed \uxxxx encoding问题及解决

《idea突然报错Malformeduxxxxencoding问题及解决》Maven项目在切换Git分支时报错,提示project元素为描述符根元素,解决方法:删除Maven仓库中的resolv... 目www.chinasem.cn录问题解决方式总结问题idea 上的 maven China编程项目突然报错,是

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型:

前端导出Excel文件出现乱码或文件损坏问题的解决办法

《前端导出Excel文件出现乱码或文件损坏问题的解决办法》在现代网页应用程序中,前端有时需要与后端进行数据交互,包括下载文件,:本文主要介绍前端导出Excel文件出现乱码或文件损坏问题的解决办法,... 目录1. 检查后端返回的数据格式2. 前端正确处理二进制数据方案 1:直接下载(推荐)方案 2:手动构造

Python绘制TSP、VRP问题求解结果图全过程

《Python绘制TSP、VRP问题求解结果图全过程》本文介绍用Python绘制TSP和VRP问题的静态与动态结果图,静态图展示路径,动态图通过matplotlib.animation模块实现动画效果... 目录一、静态图二、动态图总结【代码】python绘制TSP、VRP问题求解结果图(包含静态图与动态图

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

k8s容器放开锁内存限制问题

《k8s容器放开锁内存限制问题》nccl-test容器运行mpirun时因NCCL_BUFFSIZE过大导致OOM,需通过修改docker服务配置文件,将LimitMEMLOCK设为infinity并... 目录问题问题确认放开容器max locked memory限制总结参考:https://Access

Java中字符编码问题的解决方法详解

《Java中字符编码问题的解决方法详解》在日常Java开发中,字符编码问题是一个非常常见却又特别容易踩坑的地方,这篇文章就带你一步一步看清楚字符编码的来龙去脉,并结合可运行的代码,看看如何在Java项... 目录前言背景:为什么会出现编码问题常见场景分析控制台输出乱码文件读写乱码数据库存取乱码解决方案统一使