題目描述:給定一個入棧序列,給定一個出棧序列,判斷該出棧序列是否合法。
10年積累的成都網(wǎng)站建設(shè)、網(wǎng)站制作經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先網(wǎng)站設(shè)計后付款的網(wǎng)站建設(shè)流程,更有常寧免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
分析:假如入棧序列為1 2 3 4 5,判斷4 5 3 2 1 是否是合法的出棧順序。
兩個序列均以數(shù)組的形式給出
從兩個數(shù)組的第一個元素開始,如果棧為空,或者,棧頂元素不等于當(dāng)前出棧數(shù)組當(dāng)前下標(biāo)對應(yīng)的元素時,將當(dāng)前入棧數(shù)組中下標(biāo)所指向的元素進(jìn)行壓棧
初始狀態(tài)如下:
步驟1:把 1 進(jìn)行壓棧,并將下標(biāo)后移,如下圖所示,
步驟2:依次進(jìn)行判斷并壓棧,當(dāng)4進(jìn)棧后,此時棧頂元素等于出棧數(shù)組下標(biāo)所指向的元素,將4出棧,如下圖所示
步驟3:將 4 出棧,并將出棧數(shù)組的下標(biāo)后移,繼續(xù)判斷棧頂元素是否為當(dāng)前出棧數(shù)組下標(biāo)對應(yīng)的元素,是,則出棧,否則繼續(xù)往后執(zhí)行
步驟4:重復(fù)上述步驟,直到入棧數(shù)組中的下標(biāo)走到盡頭
當(dāng)最后一個元素入棧后,此時只需循環(huán)判斷棧頂元素是否與出棧數(shù)組當(dāng)前下標(biāo)對應(yīng)的元素相等,如果該序列合法,則棧中的元素最終都會出棧,不合法則棧永遠(yuǎn)不為空
此時,棧為空,則該序列合法。
代碼如下:
#include#include #include using namespace std; template bool IsSequenceVaild(const T* inSequence, const T* outSequence, size_t n) { assert(inSequence && outSequence); stack sc; int j = 0; //用來記錄出棧數(shù)組當(dāng)前元素的下標(biāo) for (int i = 0; i < n; ++i) { sc.push(inSequence[i]); while (!sc.empty() && sc.top() == outSequence[j]) { sc.pop(); ++j; } } return (sc.size() == 0) ? true : false; } void Test1() { int in[5] = { 1, 2, 3, 4, 5 }; int out1[5] = { 1, 2, 3, 4, 5 }; int out2[5] = { 4, 5, 3, 2, 1 }; int out3[5] = { 3, 5, 4, 2, 1 }; int out4[5] = { 3, 5, 4, 2, 1 }; int out[5] = { 4, 5, 3, 1, 2 }; cout << IsSequenceVaild (in, out1, 5) << endl; cout << IsSequenceVaild (in, out2, 5) << endl; cout << IsSequenceVaild (in, out3, 5) << endl; } void main() { Test1(); system("pause"); }