棧的壓入 彈出序列和棧所有可能的彈出順序

2021-06-21 04:20:12 字數 992 閱讀 4626

#include #include #include using namespace std;  

bool ispoporder(char* ppush, char * ppop, int nlength);

void permutation(char* str,int length)

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

break;

stackdata.pop();

pnextpop ++;

} if(stackdata.empty() && pnextpop - ppop == nlength)

bpossible = true;

} return bpossible;

}int main()

輸出字串的所有符合壓入彈出順序的序列。這裡需要求出所有的排列然後進而驗證是否滿足彈出順序。下面介紹一種遞迴的方式,直接輸出所有可能彈出順序的序列。

#include #include #include #include using namespace std;

// seq 是存放好了的元素,q是出棧的元素,result 存放所有可能出棧情況,in out 為進棧出棧次數

void inoutstack(int in,int out,deque&q,stack&s,dequeseq,vector> &result)

if(in>0)

if(out>0 && in> vc;

dequeq,seq;

int i;

for (i=0;i<4;i++)

stacks;

inoutstack(i,i,q,s,seq,vc);

int count = 0;

for (vector> ::iterator iter = vc.begin();iter!=vc.end(); iter++)

count++;

cout<

棧 棧的壓入和彈出序列

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

棧的壓入和彈出序列

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

棧的壓入和彈出序列

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