Java栈之链式栈存储结构的实现代码

 更新时间:2017年04月30日 10:48:48   投稿:lqh  
这篇文章主要介绍了Java栈之链式栈存储结构的实现代码的相关资料,需要的朋友可以参考下

Java栈之链式栈存储结构实现

一、链栈

采用单链表来保存栈中所有元素,这种链式结构的栈称为链栈。

二、栈的链式存储结构实现

package com.ietree.basic.datastructure.stack;

/**
 * 链栈
 *
 * Created by ietree
 * 2017/4/29
 */
public class LinkStack<T> {

  // 定义一个内部类Node,Node实例代表链栈的节点
  private class Node {

    // 保存节点的数据
    private T data;
    // 指向下个节点的引用
    private Node next;
    // 无参构造器
    public Node() {
    }
    // 初始化全部属性的构造器
    public Node(T data, Node next) {

      this.data = data;
      this.next = next;

    }

  }
  // 保存该链栈的栈顶元素
  private Node top;
  // 保存该链栈中已包含的节点数
  private int size;
  // 创建空链栈
  public LinkStack() {
    // 空链栈,top的值为null
    top = null;

  }

  // 以指定数据元素来创建链栈,该链栈只有一个元素
  public LinkStack(T element) {

    top = new Node(element, null);
    size++;

  }

  // 返回链栈的长度
  public int length() {

    return size;

  }

  // 进栈
  public void push(T element) {

    // 让top指向新创建的元素,新元素的next引用指向原来的栈顶元素
    top = new Node(element, top);
    size++;

  }

  // 出栈
  public T pop() {

    Node oldTop = top;
    // 让top引用指向原栈顶元素的下一个元素
    top = top.next;
    // 释放原栈顶元素的next引用
    oldTop.next = null;
    size--;
    return oldTop.data;

  }

  // 访问栈顶元素,但不删除栈顶元素
  public T peek(){

    return top.data;

  }

  // 判断链栈是否为空栈
  public boolean empty() {

    return size == 0;

  }

  // 请空链栈
  public void clear() {

    top = null;
    size = 0;

  }

  public String toString() {

    // 链栈为空栈时
    if (empty()) {

      return "[]";

    } else {

      StringBuilder sb = new StringBuilder("[");
      for (Node current = top; current != null; current = current.next) {

        sb.append(current.data.toString() + ", ");

      }

      int len = sb.length();
      return sb.delete(len - 2, len).append("]").toString();
    }

  }

}

测试类:

package com.ietree.basic.datastructure.stack;

/**
 * Created by ietree
 * 2017/4/29
 */
public class LinkStackTest {

  public static void main(String[] args) {

    LinkStack<String> stack = new LinkStack<String>();

    stack.push("aaaa");
    stack.push("bbbb");
    stack.push("cccc");
    stack.push("dddd");
    System.out.println(stack);

    System.out.println("访问栈顶元素:" + stack.peek());

    System.out.println("第一次弹出栈顶元素:" + stack.pop());

    System.out.println("第二次弹出栈顶元素:" + stack.pop());

    System.out.println("两次pop之后的栈:" + stack);

  }

}

程序输出:

[dddd, cccc, bbbb, aaaa]
访问栈顶元素:dddd
第一次弹出栈顶元素:dddd
第二次弹出栈顶元素:cccc
两次pop之后的栈:[bbbb, aaaa]

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • Java concurrency之AtomicLongFieldUpdater原子类_动力节点Java学院整理

    Java concurrency之AtomicLongFieldUpdater原子类_动力节点Java学院整理

    AtomicLongFieldUpdater可以对指定"类的 'volatile long'类型的成员"进行原子更新。它是基于反射原理实现的。下面通过本文给大家分享Java concurrency之AtomicLongFieldUpdater原子类的相关知识,感兴趣的朋友一起看看吧
    2017-06-06
  • 详解如何在SpringBoot中使用WebMvc

    详解如何在SpringBoot中使用WebMvc

    Spring Boot 是一个快速、简单的开发框架,在 Spring Boot 中,我们可以使用 WebMvc 来构建 Web 应用程序,所以本文就来讲讲如何在SpringBoot中使用WebMvc吧
    2023-06-06
  • 泛型的类型擦除后fastjson反序列化时如何还原详解

    泛型的类型擦除后fastjson反序列化时如何还原详解

    这篇文章主要为大家介绍了泛型的类型擦除后fastjson反序列化时如何还原详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • 基于maven的ssm框架整合的示例代码

    基于maven的ssm框架整合的示例代码

    本篇文章主要介绍了基于maven的ssm框架整合的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-12-12
  • java如何实现获取客户端ip地址的示例代码

    java如何实现获取客户端ip地址的示例代码

    本文主要介绍了java如何实现获取客户端ip地址,主要包括java获取客户端ip地址工具类使用实例、应用技巧,文中通过示例代码介绍的非常详细,感兴趣的小伙伴们可以参考一下
    2022-04-04
  • Java SpringMVC 集成静态资源的方式你了解吗

    Java SpringMVC 集成静态资源的方式你了解吗

    本篇文章主要介绍了SpringMVC集成静态资源的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2021-10-10
  • Java实现权重随机获取值或对象的方法

    Java实现权重随机获取值或对象的方法

    这篇文章主要介绍了Java实现权重随机获取值或对象的方法,treeMap是一种基于红黑树实现的有序映射表,提供了一系列的方法来操作映射表中的元素,其中tailMap方法是用于返回映射表中大于或等于给定键的部分视图,需要的朋友可以参考下
    2023-11-11
  • Java数据结构之双端链表原理与实现方法

    Java数据结构之双端链表原理与实现方法

    这篇文章主要介绍了Java数据结构之双端链表原理与实现方法,简单描述了双端链表的概念、原理并结合实例形式分析了java实现双端链表的相关操作技巧,需要的朋友可以参考下
    2017-10-10
  • Springboot @Async多线程获取返回值方式

    Springboot @Async多线程获取返回值方式

    这篇文章主要介绍了Springboot @Async多线程获取返回值方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • SpringBoot使用@valid进行参数校验的流程步骤

    SpringBoot使用@valid进行参数校验的流程步骤

    SpringBoot 提供了一种方便的方式来进行参数校验:使用 Hibernate Validator,Spring Boot 提供了一种方便的方式来进行参数校验:使用 Hibernate Validator,所以本文给大家介绍了SpringBoot使用@valid进行参数校验的流程步骤,需要的朋友可以参考下
    2023-09-09

最新评论