劍指offer 5 用兩個棧實現佇列

2021-09-02 01:49:55 字數 597 閱讀 9150

題目描述

用兩個棧來實現乙個佇列,完成佇列的push和pop操作。 佇列中的元素為int型別。

解題思路

需要用棧來模擬佇列的push和pop操作。

要知道,棧是先進後出,而佇列是先進先出,所以用棧實現佇列的時候,需要兩個棧,進棧可以直接進棧就ok,但是需要首先將兩個棧合為乙個棧,但是出棧的話,需要將原先乙個棧中的元素都出棧到另乙個棧中,這樣才能取到第乙個進棧的元素。

push:將元素進棧a

pop:判斷棧b是否為空,如果為空,則將棧a中所有元素pop,並push進棧b,棧b出棧,如果不為空,棧b直接出棧。

要知道,棧是先進後出,而佇列是先進先出

**如下

class solution

stack1.push(node);

}int pop()

a=stack2.top();

stack2.pop();

return a;

}private:

stackstack1;

stackstack2;

};

劍指offer 5 用兩個棧實現佇列

題目描述 用兩個棧來實現乙個佇列,完成佇列的push和pop操作。佇列中的元素為int型別。思路 棧 先進後出,佇列 先進先出 1 2 3 棧 3 2 1 1 2 3 佇列 1 2 3 stack1進棧後為1 2 3 出棧並儲存在stack2中為3 2 1,stack2出棧就和佇列一致了。push,...

劍指Offer 5 用兩個棧實現佇列

description用兩個棧來實現乙個佇列,完成佇列的push和pop操作。佇列中的元素為int型別。注 不考慮邊緣情況,如 在兩個stack都空的時候pop 作為乙個lifo的資料結構,stack中的元素在彈出的時候為反序。而為了實現乙個fifo的queue,我們就需要將反序的元素再push進令...

劍指Offer5 用兩個棧實現佇列

用兩個棧來實現乙個佇列,完成佇列的push和pop操作。佇列中的元素為int型別。使用stack1和stack2,進棧時都進stack1,出棧時,將stack1依次放入stack2中,再從stack2 棧,當stack2中為空時,再將stack1中的元素一次放入stack2中。class solut...