Java集合---栈

栈,满足先进后出(FILO)原则。可以使用Deque(双端队列)来实现栈的数据结构,Deque是Queue的子接口。

基本操作:

import java.util.Deque;
import java.util.LinkedList;

/**
 * 栈
 * 存储一组元素,但是存取元素必须遵循先进后出原则。
 * 通常为了实现后退这类功能时会使用栈 
 */
public class StackDemo {

    public static void main(String[] args) {
        /*
         * java.util.Deque
         * 双端队列,两端都可以进出队。
         * 当只调用从一端进出队操作时,就形成了栈结构。
         * 因此,双端队列为栈提供了两个方法: push, pop 
         */
        Deque<String> stack = new LinkedList<String>();
        /*
         * void push(E e)
         * 入栈操作,最后入栈的元素在栈顶(第一个元素位置) 
         */
        stack.push("one");
        stack.push("two");
        stack.push("three");
        stack.push("four");
        System.out.println(stack);
        /* 
         * E pop()
         * 出栈操作
         */
        String str = stack.pop();
        System.out.println(str);
        System.out.println(stack);

        //只得到栈顶元素,但是不出栈
        str = stack.peek();    
        System.out.println(str);
        System.out.println(stack);

        /*
         * 遍历 
         */
        while(stack.size()>0){
            str = stack.pop();
            System.out.println(str);
        }
        System.out.println(stack);


    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值