棧的push pop序列 資料結構

2021-07-02 16:40:18 字數 821 閱讀 2412

題目:輸入兩個整數序列。其中乙個序列表示棧的

push

順序,判斷另乙個序列有沒有可能是對應的

pop順序。為了簡單起見,我們假設

push

序列的任意兩個整數都是不相等的。

比如輸入的push序列是1、2、3、4、5,那麼4、5、3、2、1就有可能是乙個pop系列。因為可以有如下的push和pop序列:push 1,push 2,push 3,push 4,pop,push 5,pop,pop,pop,pop,這樣得到的pop序列就是4、5、3、2、1。但序列4、3、5、1、2就不可能是push序列1、2、3、4、5的pop序列。

#include#includeusing namespace std;

bool ispossiblepoporder(int *push, int *pop, int length)

stackdata.push(*pnextpush);

if(pnextpush - push < length)else

}if(stackdata.top() != *pnextpop)

stackdata.pop();

pnextpop++;

} if(stackdata.empty() && pnextpop - pop == length)

return ispossible; }}

int main();

int pop[5] = ;

bool result = ispossiblepoporder(push, pop, 5);

return 0;

}

棧的push pop序列

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

棧的push pop序列

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

棧的PUSH POP序列

輸入兩個整數序列,其中乙個表示棧的push順序,判斷另乙個序列有沒有可能是對應的pop序列。下面使用乙個棧來模擬這個操作過程,棧頂元素等於出棧序列中的元素時出棧,不等於時入棧。如果棧正常pop直到為空,說明序列是對應的pop序列返回真,否則返回假 1 pst 為已經初始化的棧 2 input為輸入棧...