出棧合法性 STL 棧的應用

2021-08-01 02:56:12 字數 1312 閱讀 1605

題目描述

已知自然數1,2,…,n(1<=n<=100)依次入棧,請問序列c1,c2,…,cn是否為合法的出棧序列。

輸入

輸入包含多組測試資料。

每組測試資料的第一行為整數n(1<=n<=100),當n=0時,輸入結束。

第二行為n個正整數,以空格隔開,為出棧序列。

輸出

對於每組輸入,輸出結果為一行字串。

如給出的序列是合法的出棧序列,則輸出yes,否則輸出no。

樣例輸入

5 3 4 2 1 5

5 3 5 1 4 2

0樣例輸出

yes

no**

用stl中stack的方法:

#include

#include

#include

#include

using

namespace

std;

int main()

else

if(a[k]==s.top())else

}if(flag)

printf("yes\n");

else

printf("no\n");

}return

0;}

自己寫的stack棧的方法

#include

#include

#include

#include

#define maxsize 100

using

namespace

std;

typedef

int selemtype;

typedef

struct

sqstack;

void initstack(sqstack &s)

bool push(sqstack &s,selemtype e)

selemtype pop(sqstack &s)

char gettop(sqstack s)

int main()

else

if(a[k]==gettop(s))else

}if(flag)

printf("yes\n");

else

printf("no\n");

}return

0;}

出棧合法性

題目描述 已知自然數1,2,n 1 n 100 依次入棧,請問序列c1,c2,cn是否為合法的出棧序列。輸入包含多組測試資料。每組測試資料的第一行為整數n 1 n 100 當n 0時,輸入結束。第二行為n個正整數,以空格隔開,為出棧序列。對於每組輸入,輸出結果為一行字串。如給出的序列是合法的出棧序列...

出棧的合法性

1788 出棧合法性 時間限制 1 sec 記憶體限制 32 mb 提交 153 解決 60 提交 狀態 討論版 題目描述 已知自然數1,2,n 1 n 100 依次入棧,請問序列c1,c2,cn是否為合法的出棧序列。輸入 輸入包含多組測試資料。每組測試資料的第一行為整數n 1 n 100 當n 0...

出棧的合法性檢測

對於乙個給定的入棧順序,可能的出棧順序會有很多,但是肯定都要遵循棧 後進先出 的特點,那麼怎麼進行合法性檢測呢?演算法思想如下 定義變數inindex標記入棧序列的當前位置,定義outindex標記出棧序列的當前位置 對inindex和outindex處的數進行比較,如果相同,同時往後走。如果不相同...