简单的栈应用--铁轨(小白详解)

简单的栈应用–铁轨(小白详解)

有n节车厢从A方向驶入车站,按进站顺序编号1~n。现让这些火车按照某种特定的顺序进入B方向的铁轨并驶出车站。为了重组车厢,可以借助中转站C。C是一个可以停放任意多节车厢的车站,但由于末端封顶,驶入C的车厢必须按照相反的顺序驶出C。对于每个车厢,一旦从A移入C,就不能再回到A了;一旦从C移入B,就不能回到C了。换句话说,在任意时刻,只有两种选择:A→C和C→B。请编程判断判断:按给定的出站顺序,火车能否出站。

在这里插入图片描述

第一种,顺序思考:

前提: 对于B 中的每一个节车厢,它的直接来源就是C的顶部,若无法在C 的顶部找到该序列,则不可以。

判断的序列 1(ex: 4,3,5,2,1)

我们假设进站:A 起始 为1,2,3,4,5

第一次判断

:B 处第一个为4,因此,4出现在C的顶部的情况只能是:4之前的1,2,3要进入C,

此时,A: 5

C:1,2,3

第二次判断:

B 处第二个为3,无论是第几个数,它的直接来源只可能是C 的顶部。C 的

顶部是3 ,为了方便后续的判断,我们先将C中的3 弹出

此时,A: 5

C:1,2

第三次判断:

B 处第三个为 5,此时C 的顶部是2,我们需要在即将进入C 中的
剩余的A 中找到5,并让它进入C . 此时,C 的顶部有了5

此时,A: 空

后续的判断也是如此

判断的序列 2(ex: 5,4,1,2,3)

A 起始 为1,2,3,4,5

第一次判断

B处第一个为5,因此,5出现在C的顶部的情况只能是:5之前的1,2,3,4要进入C,

A:空

C:1,2,3,4

第二次判断

B 处第二个为4 在C的顶部找到了4

A:空

C:1,2,3,

第三次判断

B 处第三个为1,在C 的顶部找不到1 A也没有未进入C的,因此
这个序列不可以。

上面的思考方法是将给出的序列 顺序思考,也可以倒序思考,将B 中的序列还原回A 中,看是否可以还原 。

具体的代码及解释:

#include<cstdio>
#include<stack>//栈 所需要的头文件 
using namespace std;
const int MAXN = 1005;
int n,target[MAXN];
int main()
{
 int ok = 1;//判断参数 
    while(scanf("%d",&n) == 1 && n)
```{
        stack<int> s;//定义一个栈 
        int A = 1, B = 1;//此处 A 即为模拟中A处的车厢,B 即为猜测序列中的索引 
        for(int i = 1 ; i <= n ; i++)
            scanf("%d",&target[i]);
        
        while(B <= n)//终止条件是 判断猜测 序列 B 时 小于序列个数 
        {      //首先,判断此时 B 中的数字 target[B] ,是否可以在  A  中找到; (相当于将其压入C 在从C 弹出) 
        if(A == target[B]){A++;B++;}//如果找到了,则继续寻找下一个
        else if(!s.empty() && s.top() == target[B]){s.pop();B++;}//若C中不是空的,并且C 的顶部是 target[B] 则将C 顶部弹出 并继续判断下一个 
        else if(A <= n) s.push(A++);//如果C中没有 或者是C 中是空的,则将 A 中 数字压入C 中 继续判断 
        else {ok = 0;break;}
    }
        printf("%s\n",ok ? "Yes":"No");}
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值