深入理解数据结构(1)—用链表实现栈

栈是一种数据结构,链表也是一种数据结构。它们都是由基础的语法实现的。

如果一个数据结构可以用另外的数据结构来实现,那么可以有力的证明------"数据结构是一种思想",是一种讲语法组合起来实现某种功能的手段

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

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

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

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

在使用单链表的情况下,从头部插入------模拟入栈,头部删除------模拟出栈。同时这样操作满足了时间复杂度O(1)

每次向栈中插入一个元素,就是向这个链表前端插入一个新的"head";

每次从栈中弹出一个元素,就是从链表头部删除一个"head",然后"head = head.next";

二、代码实现

java 复制代码
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);

    }
}
相关推荐
小辉同志2 小时前
215. 数组中的第K个最大元素
数据结构·算法·leetcode··快速选择
风一样的航哥5 小时前
LeetCode 2615 等值距离和:前缀和优化O(n)解法深度解析
数据结构·算法·leetcode
khalil10207 小时前
代码随想录算法训练营Day-34动态规划03 | 01背包问题 二维、01背包问题 一维、416. 分割等和子集
数据结构·c++·算法·leetcode·动态规划·背包问题·01背包
空中海8 小时前
Redis 从零到精通:9大数据结构 × 11个高频工程实战场景完全手册
数据结构·数据库·redis
地球资源数据云9 小时前
1951-2025年中国逐年1千米逐月总降水量区域统计数据集_年表_县
大数据·数据结构·数据库·数据仓库·人工智能
cpp_250110 小时前
P2639 [USACO09OCT] Bessie‘s Weight Problem G
数据结构·算法·动态规划·题解·洛谷·背包dp
郝学胜-神的一滴10 小时前
[力扣 227] 双栈妙解表达式计算:从思维逻辑到C++实战,吃透反向波兰式底层原理
java·前端·数据结构·c++·算法
菜鸟丁小真11 小时前
LeetCode hot100 -131.分割回文串
数据结构·算法·leetcode·知识点总结
数智化精益手记局11 小时前
8d报告案例分析:拆解8d报告案例分析的8个步骤,解决生产现场重复发生的质量难题
大数据·数据结构·数据库·人工智能·精益工程
笨笨饿11 小时前
66_C语言与微控制器底层开发
linux·c语言·网络·数据结构·算法·机器人·个人开发