算法通关村-----如何基于数组和链表实现栈

实现栈的基本方法

push(T t)元素入栈

T pop() 元素出栈

Tpeek() 查看栈顶元素

boolean isEmpty() 栈是否为空

基于数组实现栈

java 复制代码
import java.util.Arrays;

public class ArrayStack<T> {
    private Object[] stack;
    private int top;

    public ArrayStack() {
        this.stack = new Object[10];
        this.top = 0;
    }

    public boolean isEmpty() {
        return top == 0;
    }

    public void expand(int size) {
        int len = stack.length;
        if (size > len) {
            size = size * 3 / 2 + 1;
            stack = Arrays.copyOf(stack, size);
        }
    }

    public T pop() {
        T t = null;
        if (top > 0) {
            t = (T) stack[top--];
        }
        return t;
    }

    public void push(T t) {
        expand(top + 1);
        stack[top++] = t;
    }
    
    public T peek(){
        T t = null;
        if(top >0){
            t = (T) stack[top-1];
        }
        return t;
    }
}

基于链表实现栈

java 复制代码
public class ListStack<T>{
    class Node<T> {
        public T t;
        public Node next;
    }
    private Node<T> head;

    public ListStack() {
    }
    
    public boolean isEmpty() {
        if(head == null){
            return true;
        }
        return false;
    }
    
    public void push(T t){
        if(head == null){
            head = new Node<T>();
            head.t = t;
            head.next = null;
        }
        Node<T> temp = new Node<T>();
        temp.t = t;
        temp.next = head;
        head = temp;
    }
    
    public T pop() {
        if(isEmpty()){
            return null;
        }
        T t = head.t;
        head = head.next;
        return t;
    }
    
    public T peek(){
        if(isEmpty()){
            return null;
        }
        T t = head.t;
        return t;
    }
}
相关推荐
故事和你915 小时前
洛谷-数据结构1-1-线性表1
开发语言·数据结构·c++·算法·leetcode·动态规划·图论
脱氧核糖核酸__5 小时前
LeetCode热题100——53.最大子数组和(题解+答案+要点)
数据结构·c++·算法·leetcode
脱氧核糖核酸__5 小时前
LeetCode 热题100——42.接雨水(题目+题解+答案)
数据结构·c++·算法·leetcode
一 乐6 小时前
电影院|基于springboot + vue电影院购票管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·电影院购票管理管理系统
恼书:-(空寄6 小时前
JVM GC 日志分析 + 常见 GC 场景 + 实战参数调优
java·jvm
消失的旧时光-19436 小时前
Spring Boot 实战(五):接口工程化升级(统一返回 + 异常处理 + 错误码体系 + 异常流转机制)
java·spring boot·后端·解耦
王老师青少年编程6 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:数列分段 Section I
c++·算法·编程·贪心·csp·信奥赛·线性扫描贪心
王老师青少年编程6 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:分糖果
c++·算法·贪心算法·csp·信奥赛·线性扫描贪心·分糖果
_日拱一卒6 小时前
LeetCode:2两数相加
算法·leetcode·职场和发展
py有趣6 小时前
力扣热门100题之零钱兑换
算法·leetcode