栈概念及代码实现

本文介绍了栈的概念,特别是其在撤销操作和浏览器回退中的应用。通过一个具体的Java实现展示了基于数组的顺序栈,包括入栈、出栈和检查是否为空的方法,并给出了测试示例。顺序栈在数据结构中扮演重要角色,提供高效的操作,如数组实现的顺序栈在添加和删除元素时具有O(1)的时间复杂度。
摘要由CSDN通过智能技术生成

目录

栈的引入

概念


栈的引入

undo操作,

浏览器页面回退到上一层,

或者大家平时用的ctrl+z都是栈顶元素出栈操作,恢复上一个状态

概念

栈是一个线性表,底层既可以用数组,也可以用链表

基于数组实现的栈——顺序栈(数组尾部的添加和删除时间复杂度为O(1))

基于链表实现的栈——链式栈(尾插和尾删)


import java.util.ArrayList;
import java.util.List;
import java.util.NoSuchElementException;

/**
 * 基于数组实现的顺序栈
 * @param <E>
 */
public class MyStack <E>{
    private int size;
//    实际存储数据的动态数组 ——ArrayList
    private List<E> data = new ArrayList<>();
    /**
     * 将val入栈
     * @param val
     */
    public void push(E val){
        data.add(val);
        size++;
    }

    /**
     * 删除栈顶元素
     * @return
     */
    public E pop(){
        if(isEmpty()){
            throw new NoSuchElementException("Stack is empty!cannot pop!");
        }
//        栈不为空,可以弹出栈顶元素
        E val= data.remove(size - 1);
        size--;
        return val;
    }
    public boolean isEmpty(){
        return size == 0;
    }

    @Override
    public String toString() {
        StringBuilder sb = new StringBuilder();
        sb.append("[");
        for (int i = 0; i < size; i++) {
            sb.append(data.get(i));
            if(i != size - 1){
                sb.append(", ");
            }
        }
        sb.append("] top");
        return sb.toString();
    }
}

public class StackTest {
    public static void main(String[] args) {
        MyStack<Integer> mystack = new MyStack<>();
        mystack.push(1);
        mystack.push(3);
        mystack.push(5);
        System.out.println(mystack);
    }
}

运行结果:

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值