出棧合法性

2021-09-22 06:01:02 字數 735 閱讀 6119

題目描述

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

輸入包含多組測試資料。

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

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

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

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

5

3 4 2 1 5

53 5 1 4 2

0

yes

no

思路

用乙個佇列放輸入的出棧序列,用乙個棧模擬入棧的情況,n次for迴圈,順序入棧1-n

每當佇列首部元素和棧頂元素相等的時候,就彈出佇列的這個元素代表匹配成功,

並且一旦有相等的元素,就while迴圈如果一直相等,佇列就一直彈

外層for迴圈結束之後,若棧為空,則出棧序列合法

#include#include#includeusing namespace std;

int main()

while(!q.empty())

while(!s.empty())

int temp;

for(int i=0;ifor(int i=1;i<=n;i++)

}if(s.empty())

else

}}

出棧的合法性

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處的數進行比較,如果相同,同時往後走。如果不相同...

出棧序列的合法性

給定乙個最大容量為 m 的堆疊,將 n 個數字按 1,2,3,n 的順序入棧,允許按任何順序出棧,則哪些數字序列是不可能得到的?例如給定 m 5 n 7,則我們有可能得到,但不可能得到。輸入格式 輸入第一行給出 3 個不超過 1000 的正整數 m 堆疊最大容量 n 入棧元素個數 k 待檢查的出棧序...