您好,登錄后才能下訂單哦!
小編給大家分享一下c++如何解決棧的壓入彈出序列問(wèn)題,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
#define _CRT_SECURE_NO_WARNINGS 1 #include<stdlib.h> #include<iostream> using namespace std; #include<vector> #include<stack> /* 題目要求: 輸入兩個(gè)整數(shù)序列,第一個(gè)序列表示棧的壓入順序,請(qǐng)判斷第二個(gè)序列是否可能為該棧的彈出順序。 假設(shè)壓入棧的所有數(shù)字均不相等。例如序列1,2,3,4,5是某棧的壓入順序, 序列4,5,3,2,1是該壓棧序列對(duì)應(yīng)的一個(gè)彈出序列,但4,3,5,1,2就不可能是該壓棧序列的彈出序列。 (注意:這兩個(gè)序列的長(zhǎng)度是相等的) */ /* 解題思路: 利用一個(gè)棧,將pushV中的元素依次插入,若棧頂元素和popV中pos元素相等則pop棧頂元素并讓pos指向下一個(gè)元素 pushV中元素插入結(jié)束若棧為空則說(shuō)明滿足條件,否則不滿足。 */ class Solution { public: bool IsPopOrder(vector<int> pushV, vector<int> popV) { stack<int> s; if (pushV.size() != popV.size()) { return false; } int i = 0; int j = 0; while (i < pushV.size()) { s.push(pushV[i++]); while (!s.empty() && s.top() == popV[j]) { s.pop(); j++; } } if (s.empty()) { return true; } else { return false; } } }; int main() { vector<int>v1{1, 2, 3, 4, 5}; vector<int>v2{ 4,5,3,2,1}; Solution s; int a=s.IsPopOrder(v1, v2); cout << a << endl; system("pause"); return 0; }
以上是“c++如何解決棧的壓入彈出序列問(wèn)題”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。