棧的壓入和彈出序列

2021-08-21 21:35:23 字數 739 閱讀 5007

題目:輸入兩個整數序列,第乙個序列表示棧的壓入順序,請判斷第二個序列是否可能為該棧的彈出順序。假設壓入棧的所有數字均不相等。例如序列1,2,3,4,5是某棧的壓入順序,序列4,5,3,2,1是該壓棧序列對應的乙個彈出序列,但4,3,5,1,2就不可能是該壓棧序列的彈出序列。(注意:這兩個序列的長度是相等的)

思路:借助乙個輔助棧,和乙個彈出序列的索引index,將整數序列依次壓入,每壓入乙個就將棧頂元素和彈出序列下標為index的元素進行比較,如果相等,彈出,並且index++,再比較,如果不等,繼續壓棧。

例如:入棧順序1,2,3,4,5

出戰順序4,5,3,2,1

過程如下

1入棧,1!=4;

2入棧,2!=4;

3入棧,3!=4;

4入棧,4=4

彈出4,3!=5

5入棧,5=5

彈出5,3=3,彈出

2=2,彈出

1=1,彈出**:

public boolean ispoporder(int  pusha,int  popa) 

int index = 0;

stackstack = new stack();

for(int i=0;i}

}if(!stack.isempty())

return true;

}

棧 棧的壓入和彈出序列

題目描述 給定兩個序列s1和s2,問是否有可能通過對s1進行入棧出棧操作得到s2?s1中每個元素都不同 思路 若彈出數字剛好是棧頂元素,則直接彈出。若要彈出的數字不在棧頂,那就繼續將源序列壓入棧中直到它在棧頂位置。若源序列都被壓入了棧中,但仍為得到要彈出的數字,則證明s2不可能是s1的乙個彈出序列。...

棧的壓入和彈出序列

輸入兩個整數序列。其中乙個序列表示棧的push順序,判斷另乙個序列有沒有可能是對應的pop順序。為了簡單起見,我們假設push序列的任意兩個整數都是不相等的。比如輸入的push序列是1 2 3 4 5,那麼4 5 3 2 1就有可能是乙個pop系列。bool ispossiblepoporder c...

棧的壓入彈出序列

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