火车编组【入门】

#include<bits/stdc++.h>
using namespace std;
char a[1111];
int top=0;
int main(){
	int n,p,c=0;
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>p;
		while(a[top]!=p){
			c++;
			a[++top]=c;
			cout<<"A";
		}
		if(top>0&&a[top]==p){
			top--;
			cout<<"B";
		}
	}
	return 0;
}
题目描述

货运火车要在编组站根据挂靠车厢到达目的地重新分组,如果一列火车有4节车厢,经过编组后,车厢的编组顺序为3,2,4,1;您知道编组站是怎么编组的吗?

小明到编组站参观后发现编组站的铁路有很多岔道,火车在岔道上来来回回地开动,最后列车编组就完成了。

小明想到学习过的栈操作,发现火车编组的过程就是由若干进栈,出栈操作构成的。于是小明编了一个程序,只要知道最后的编组要求,就能将编组方案输出。

比如,有4辆火车,初始的顺序是1 2 3 4,最后编组的结果是3 2 4 1,那么只需要准备一个栈,让这4辆火车按照:进栈、进栈、进栈、出站、出站、进栈、出站、出站的顺序进行栈的操作就可以得到3 2 4 1的编组结果。

输入

第1行1个正整数 n,n<=100,n个小于或等于 n 的正整数,表示有 n节车厢,编号为 1,2,3,……,n;编组时按照编号进栈,

第2行表示列车经过编组后的车厢编号顺序;数据保证一定有解!

输出

一行一个由大写字母 A 和 B 构成的字符串,A表示进栈,B 表示出栈。表示编组时进栈出栈的操作序列;

样例输入 复制
4
3 2 4 1
样例输出 复制
AAABBABB
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值