棧的壓入彈出序列

2021-09-11 01:15:27 字數 499 閱讀 7349

直觀的想法就是模擬第乙個序列的數字依次入棧,並按照第二個序列依次彈出,如果第乙個序列全部入棧,並最後棧中元素都被彈出來,就說明第二個序列是該棧的彈出順序。

建立乙個輔助棧;

將第乙個序列的數字壓入輔助棧;

如果第二個序列的下乙個彈出數字剛好是棧頂數字,則直接彈出,第二個序列彈出當前數字,輔助棧也彈出該數字;

否則,就把第乙個序列中尚未入棧的數字壓入輔助棧,直到把第二個序列中下乙個需要彈出的數字壓入棧頂為止。

如果第乙個序列的所有數字都已經入棧了,仍然沒有找到下乙個彈出的數字,那麼第二個序列不可能是乙個彈出序列

class solution

if(stackdata.top()!=popv[j])

return false;

stackdata.pop();

j++;

}if(stackdata.empty()&&jlength)

return true;

}return false;}};

棧的壓入彈出序列

題目 輸入兩個整數序列,第乙個序列表示棧的壓入順序,請判斷第二個序列是否為該棧的彈出順序。假設壓入棧的所有數字均不相等。例如序列1,2,3,4,5是某棧的壓棧序列,序列4,5,3,2,1是該棧序列對應的乙個彈出序列,但4,3,5,1,2就不可能是該壓棧序列的彈出序列。解答 可以用乙個輔助的棧來儲存入...

棧的壓入 彈出序列

輸入兩個整數序列,第乙個序列表示棧的壓入順序,判斷兩個序列是否為該棧的彈出順序。假設壓入棧的所有數字均不相等。例如序列1 2 3 4 5是某棧的壓棧序列,序列4 5 3 2 1是該壓棧序列對應的乙個彈出序列,但4 3 5 1 2就不可能是該壓棧序列的彈出序列。bool ispoporder cons...

棧的壓入彈出序列

1.問題描述 輸入兩個整數序列,第乙個序列表示棧的壓入序列,請判斷第二個序列是否為該棧的彈出序列。假設壓入棧的所有數字均不相等。例如序列1,2,3,4,5是某棧的壓棧序列,序列4,5,3,2,1是該棧序列對應的乙個彈出序列,但 4,3,5,1,2,就不可能是該壓棧序列的彈出序列。來自 劍指offer...