棧是Vector的一個子類,它實現了一個標準的後進先出的棧。 堆棧只定義了預設構造函數,用來創建一個空棧。 堆棧除了包括由Vector定義的所有方法,也定義了自己的一些方法。 棧常用的五個方法: boolean empty() :測試堆棧是否為空。 object peek():查看棧頂元素,但是不移 ...
棧是Vector的一個子類,它實現了一個標準的後進先出的棧。
堆棧只定義了預設構造函數,用來創建一個空棧。 堆棧除了包括由Vector定義的所有方法,也定義了自己的一些方法。
棧常用的五個方法:
boolean empty() :測試堆棧是否為空。
object peek():查看棧頂元素,但是不移除。
object pop():返回棧頂元素,並移除。
object push(object element):入棧
int search(object element):返回對象在棧中的元素,以1為基數
import java.util.*; public class StackDemo { static void showpush(Stack st, int a) { st.push(new Integer(a)); System.out.println("push(" + a + ")"); System.out.println("stack: " + st); } static void showpop(Stack st) { System.out.print("pop -> "); Integer a = (Integer) st.pop(); System.out.println(a); System.out.println("stack: " + st); } public static void main(String args[]) { Stack st = new Stack(); System.out.println("stack: " + st); showpush(st, 42); showpush(st, 66); showpush(st, 99); showpop(st); showpop(st); showpop(st); try { showpop(st); } catch (EmptyStackException e) { System.out.println("empty stack"); } } }
stack: [ ]
push(42)
stack: [42]
push(66)
stack: [42, 66]
push(99)
stack: [42, 66, 99]
pop -> 99
stack: [42, 66]
pop -> 66
stack: [42]
pop -> 42
stack: [ ]
pop -> empty stack