Stack queue作業題作者:@小萌新
創新互聯專業為企業提供陸川網站建設、陸川做網站、陸川網站設計、陸川網站制作等企業網站建設、網頁設計與制作、陸川企業網站模板建站服務,十年陸川做網站經驗,不只是建網站,更提供有價值的思路和整體網絡服務。
專欄:@C++初階
作者簡介:大二學生 希望能和大家一起進步!
本篇博客簡介:實現幾道Stack和queue的作業題
它問題的題目描述是這樣子的
什么意思呢? 用一句話解釋下 就是設計一個棧
這個棧除了能夠執行正常的操作之外我們還要可以隨時的獲取這個棧中的最小元素
那我們想想看我們的思路是什么?
是不是只要設計兩個棧就好了?
一個棧正常的存放數據
一個棧比較下當前存放的數據是否比自己最小的數據小
如果小于自己最小的數據那就入這個數據 如果不小于自己最小的數據 那么就再入一次目前來說最小的數據
這道題的主要難點在于思路 思路解決了 后面的問題也就解決了
代碼表示如下
class MinStack {public:
MinStack() {}
void push(int val)
{_stk.push(val);
if (_stkmin.empty())
{_stkmin.push(val);
}
else
{if (_stkmin.top() >val)
{_stkmin.push(val);
}
else
{_stkmin.push(_stkmin.top());
}
}
}
void pop()
{_stk.pop();
_stkmin.pop();
}
int top()
{return _stk.top();
}
int getMin()
{return _stkmin.top();
}
private:
stack_stk;
stack_stkmin;
};
棧的壓入彈出序列題目如下
這里的題目要求我們來設計一個算法 檢驗棧的插入彈出序列是否是有效的
也就是說 最后能否完全彈出所有的數據
那想想看 我們這個時候應該怎么做呢?
要設計一個算法去計算有點太難了是不是
那么我們可不可以直接使用一個棧來模擬這個過程呢?
如果模擬通過是不是就表示肯定能通過了啊
我們一開始可以設計兩個指針
一個指針指向插入數據的數組
一個指針指向刪除數據的數組
像這樣
當我們的出棧序列不等于入棧序列的時候那就一直入棧
當我們的出棧序列等于入棧序列的時候呢 就開始出棧
原則是:出掉所有符合出棧序列的數
像是這種情況 就代表出掉了所有的可以出的序列了
所以我們這個時候就停止出棧
當5也入棧的時候
這個時候就是按照 5 3 2 1的順序出棧了
那么我們的代碼表示如下
class Solution {public:
bool IsPopOrder(vectorpushV,vectorpopV)
{stackst;
int pushvi = 0;
int popvi = 0;
while(pushvi< pushV.size())
{st.push(pushV[pushvi]);
pushvi++;
// 判斷是否要刪除
while(!st.empty() && st.top() == popV[popvi])
{st.pop();
popvi++;
}
}
// 最后判斷下結束
return popvi == popV.size();
}
};
運行結果如下
逆波蘭表達式問題題目如下
這里大家首先要理解逆波蘭表達式究竟是什么?
大家可以上各類視頻網站詳細了解下 由于博客篇幅限制 這里
就只談逆波蘭表達式如何使用
它的原則其實很簡單就只有兩條
1 如果我們遍歷到加減乘除四個字符串 那么我們就從棧中取出兩個元素來分別作為左操作數和右邊操作進行運算 之后還將它入棧
2 如果我們遍歷到了數字字符串 那么我們就將它轉化成整型數字 然后存放到棧當中去
那么對應的代碼表示也就很簡單了
long num1 = st.top(); st.pop();
long num2 = st.top(); st.pop();
if (x == "+") st.push(num2 + num1);
if (x == "-") st.push(num2 - num1);
if (x == "*") st.push(num2 * num1);
if (x == "/") st.push(num2 / num1);
st.push(stol(x));
最后在棧里面的數字其實就是我們要求的答案了
那么完整的代碼表示如下
class Solution {public:
int evalRPN(vector& tokens) {stackst;
for (auto x : tokens)
{if (x == "+" || x =="-" || x =="*" || x =="/")
{long num1 = st.top(); st.pop();
long num2 = st.top(); st.pop();
if (x == "+") st.push(num2 + num1);
if (x == "-") st.push(num2 - num1);
if (x == "*") st.push(num2 * num1);
if (x == "/") st.push(num2 / num1);
}
else
{st.push(stol(x));
}
}
return st.top();
}
};
運行結果如下
總結
講解了棧的三道題目 最小棧問題 棧的壓入彈出序列 逆波蘭表達式問題
你是否還在尋找穩定的海外服務器提供商?創新互聯www.cdcxhl.cn海外機房具備T級流量清洗系統配攻擊溯源,準確流量調度確保服務器高可用性,企業級服務器適合批量采購,新人活動首月15元起,快前往官網查看詳情吧
網站名稱:C++初階作業Stack&&queue作業題一-創新互聯
鏈接URL:http://vcdvsql.cn/article32/dshisc.html
成都網站建設公司_創新互聯,為您提供響應式網站、面包屑導航、動態網站、定制開發、網站收錄、Google
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯