Java——栈和队列

本文介绍了Java中栈和队列的概念及其使用方法。栈遵循先入后出(LIFO)原则,提供了压栈、出栈、查看栈顶元素和检查栈是否为空等操作。队列则遵循先入先出(FIFO)原则,支持元素入队、出队、查看队头元素和检查队列是否为空。此外,还展示了自定义栈类`MyStack`的实现,该类使用数组动态扩容来管理元素。
摘要由CSDN通过智能技术生成

概念

和ArrayList和LinkedList一样,是一种线性表,但是需要遵循特殊的规定——先入后出,后入先出。
数据插入栈的操作叫做压栈,删除叫做出栈

栈的使用方法

方法功能
Stack()构造一个空的栈
E push(E e)将e入栈,并返回e
E pop()将栈顶元素出栈并返回
E peek()获取栈顶元素
int size()获取栈中有效元素个数
boolean empty()检测栈是否为空

MyStack的实现

import java.util.Arrays;

public class MyStack {
    public int[] elem;
    public int usedSize;

    public MyStack() {
        this.elem = new int[5];
    }

    public void push(int val){
        if(isFUll()){
            this.elem = Arrays.copyOf(this.elem,2 * this.elem.length);
        }
        this.elem[this.usedSize] = val;
        this.usedSize++;
    }

    public boolean isFUll(){
        return this.usedSize == this.elem.length;
    }

    public int pop(){
        if(isEmpty()){
            throw new RuntimeException("the stack is empty");
        }
        int oldVal = this.elem[usedSize - 1];
        this.usedSize--;
        return oldVal;
    }

    public boolean isEmpty(){
        return this.usedSize == 0;
    }

    public int peak(){
        if(isEmpty()){
            throw new RuntimeException("the stack is empty");
        }
        return this.elem[usedSize - 1];
    }
}

队列

概念

和栈差不多,只不过要求是先入先出,后入后出

使用方法

方法功能
boolean offer(E e)入队列
E poll()出队列
peek()获取队头元素
int size()获取队列中有效元素个数
boolean isEmpty()检测队列是否为空
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值