0
点赞
收藏
分享

微信扫一扫

小黑子—spring:第一章

德州spark 2023-10-27 阅读 28

一、栈的特点——要实现哪些功能?

既然要用链表来模拟栈,那么要实现哪些功能?

  1. 栈是一种特殊的线性表,只允许在固定一端进行插入和删除元素操作
  2. 后进先出

那么对于这两个特性,我们可以做出如下设想:

二、代码实现 

public class MyStack {
    /*创建链表的节点*/
    static class Node{
        public int val;
        public Node next;

        public Node(int val){
            this.val = val;
        }
    }
    public Node head;
    public int size;

    //实现入栈方法
    public void push(int val){
        Node node = new Node(val);
        /*如果此时链表中没有节点,那么将node设为head,并将有效元素个数size加1
        * 如果链表中已经有元素的话,将node节点头插到head节点前,并设为head*/
        if (size == 0){
            head = node;
        }else {
            node.next = head;
            head = node;
        }
        size++;
    }
    //实现出栈方法
    /*返回当前头节点的值,并将头节点后移*/
    public int pop(){
        int h = head.val;
        head = head.next;
        size--;
        return h;
    }
    //获取栈顶元素的peek方法
    public int peek(){
        return head.val;
    }
    //判断栈是否为空
    public boolean empty(){
        return size == 0;
    }

    public static void main(String[] args) {
        MyStack stack = new MyStack();
        stack.push(12);
        stack.push(24);
        stack.push(26);
        stack.push(58);
        int b = stack.pop();
        int a = stack.peek();
        System.out.println(b);
        System.out.println(a);

    }
}

 

举报

相关推荐

第一章 Spring Boot入门

第一章 绪论

第一章综述

第一章作业

第一章 起步

第一章.概论

0 条评论