棧的特點:先進后出
隊列特點:先進先出
//實現兩個棧實現一個隊列 //每次都push到_s1中,pop從_s2,提高效率(每次不用互相倒棧)
#pragma once #include<iostream> #include<stack> #include<queue> #include<assert.h> using namespace std; template<class T> class Queue { public: void Push(const T& x) { _s1.push(x); } void Pop() { if (_s2.empty()) { while (!_s1.empty()) { _s2.push(_s1.top()); _s1.pop(); } } //斷言當_s2為空時,不執行 (庫中實現_s2.pop()也已斷言,實不實現都行!!!)防止自己實現的棧出錯 assert(!_s2.empty()); _s2.pop(); } bool Empty() { return _s1.empty() && _s2.empty(); } int Size() { return _s1.size() + _s2.size(); } T& Front() { if (_s2.empty()) { while (!_s1.empty()) { _s2.push(_s1.top()); _s1.pop(); } } assert(!_s2.empty()); return _s2.top(); } T& Back() { if (_s1.empty()) { while (!_s2.empty()) { _s1.push(_s2.top()); _s2.pop(); } } assert(_s1.empty()); return _s1.top(); } protected: stack<T> _s1; stack<T> _s2; }; void Test1() { Queue<int> q1; q1.Push(1); q1.Push(2); q1.Push(3); q1.Push(4); q1.Push(5); q1.Push(6); q1.Pop(); q1.Pop(); q1.Pop(); q1.Pop(); q1.Pop(); q1.Pop(); //q1.Pop(); //cout << q1.Front() << endl; //cout << q1.Back() << endl; //cout << q1.Empty() << endl; cout << q1.Size() << endl; }
創新互聯www.cdcxhl.cn,專業提供香港、美國云服務器,動態BGP最優骨干路由自動選擇,持續穩定高效的網絡助力業務部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統配攻擊溯源,準確進行流量調度,確保服務器高可用性。佳節活動現已開啟,新人活動云服務器買多久送多久。
網站名稱:兩個棧實現一個隊列-創新互聯
瀏覽路徑:http://m.kartarina.com/article44/cddjee.html
成都網站建設公司_創新互聯,為您提供外貿建站、全網營銷推廣、搜索引擎優化、網站內鏈、商城網站、用戶體驗
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯