堆疊是一種經典的後進先出的線性結構,相關的操作主要有「入棧」(在堆疊頂插入乙個元素)和「出棧」(將棧頂元素返回並從堆疊中刪除)。本題要求你實現另乙個附加的操作:「取中值」——即返回所有堆疊中元素鍵值的中值。給定 n 個元素,如果 n 是偶數,則中值定義為第 n/2 小元;若是奇數,則為第 (n+1)/2 小元。
輸入的第一行是正整數 n(≤105)。隨後 n 行,每行給出一句指令,為以下 3 種之一:
push key
poppeekmedian
其中key
是不超過 105 的正整數;push
表示「入棧」;pop
表示「出棧」;peekmedian
表示「取中值」。
對每個push
操作,將key
插入堆疊,無需輸出;對每個pop
或peekmedian
操作,在一行中輸出相應的返回值。若操作非法,則對應輸出invalid
。
17
poppeekmedian
push 3
peekmedian
push 2
peekmedian
push 1
peekmedian
poppop
push 5
push 4
peekmedian
poppop
poppop
invalid
invalid32
2124
453invalid
這題加深了我對stl的理解
雖然題目說是棧 但以我的水平不會用棧做 關鍵是取中間值
取中間值用set模擬很方便 但是又維護不了出棧入棧
可以用vector 模擬 得要兩個vector
乙個模擬棧 這個很方便 pushback popback即可
還有乙個維護公升序 用lower-bound取中間值
注意: v,erase(i) i為下標
迭代器: vector::iterator it
還有就是注意vector 中insert的操作
#includeusingnamespace
std;
//input
#define rep(i,a,b) for(int i=(a);i<=(b);i++)
#define ri(n) scanf("%d",&(n))
#define rii(n,m) scanf("%d%d",&n,&m);
#define riii(n,m,k) scanf("%d%d%d",&n,&m,&k)
#define rs(s) scanf("%s",s);
#define ll long long
#define rep(i,n) for(int i=0;i<(n);i++)
#define clr(a,v) memset(a,v,sizeof a)
/////////////////////////////////
/int
main()
}if(s[1]=='u'
)
if(s[1]=='e'
)
}}
return0;
}
L3 002 特殊堆疊 (雙陣列模擬棧)
堆疊是一種經典的後進先出的線性結構,相關的操作主要有 入棧 在堆疊頂插入乙個元素 和 出棧 將棧頂元素返回並從堆疊中刪除 本題要求你實現另乙個附加的操作 取中值 即返回所有堆疊中元素鍵值的中值。給定 n 個元素,如果 n 是偶數,則中值定義為第 frac2 小元 若是奇數,則為第 frac2 小元。...
特殊堆疊 30 分
堆疊是一種經典的後進先出的線性結構,相關的操作主要有 入棧 在堆疊頂插入乙個元素 和 出棧 將棧頂元素返回並從堆疊中刪除 本題要求你實現另乙個附加的操作 取中值 即返回所有堆疊中元素鍵值的中值。給定 n 個元素,如果 n 是偶數,則中值定義為第 n 2 小元 若是奇數,則為第 n 1 2 小元。輸入...
用堆疊模擬佇列,和用佇列模擬堆疊
最近在看 演算法導論 第十章裡面有一題是用了 兩個堆疊模擬乙個佇列,我設計的演算法如下 堆疊a和b,a用作入隊,b出隊 1 判隊滿 如果a滿且b不為空,則隊滿 2 判隊空 如果a和b都為空,則隊空 3 入隊 首先判隊滿。若隊不滿 1 棧a若不滿,則直接壓入棧a 2 若a滿,則將a中的所有元素彈出到棧...