用兩個棧來實作一個隊列,完成隊列的Push和Pop操作。 隊列中的元素為int類型。(java)
1. 題目描述
用兩個棧來實作一個隊列,完成隊列的Push和Pop操作。 隊列中的元素為int類型。
2. 方法思路
(1)其實看題目可以知道,他說用兩個棧(棧先進後出),是以應該可以想到每個棧的用途都不一樣。其實就是一個棧用作進棧,一個棧用作出棧就可以實作隊列先進先出的特性。
(2)…
3. 代碼實作
(1)
import java.util.Stack;
public class Solution {
Stack<Integer> stack1 = new Stack<Integer>();
Stack<Integer> stack2 = new Stack<Integer>();
public void push(int node) {
stack1.push(node);
}
public int pop() {
if(stack1.isEmpty()&&stack2.isEmpty()){
return -1;
}
if(stack2.isEmpty())
{
while(!stack1.isEmpty()){
stack2.push(stack1.pop());
}
}
return stack2.pop();
}
}
(2)
................思考中.............