特殊堆疊 模擬

2022-05-01 17:21:09 字數 1749 閱讀 7513

堆疊是一種經典的後進先出的線性結構,相關的操作主要有「入棧」(在堆疊頂插入乙個元素)和「出棧」(將棧頂元素返回並從堆疊中刪除)。本題要求你實現另乙個附加的操作:「取中值」——即返回所有堆疊中元素鍵值的中值。給定 n 個元素,如果 n 是偶數,則中值定義為第 n/2 小元;若是奇數,則為第 (n+1)/2 小元。

輸入的第一行是正整數 n(≤10​5​​)。隨後 n 行,每行給出一句指令,為以下 3 種之一:

push key

poppeekmedian

其中key是不超過 10​5​​ 的正整數;push表示「入棧」;pop表示「出棧」;peekmedian表示「取中值」。

對每個push操作,將key插入堆疊,無需輸出;對每個poppeekmedian操作,在一行中輸出相應的返回值。若操作非法,則對應輸出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的操作  

#includeusing

namespace

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中的所有元素彈出到棧...