Java实现线性表的链式存储

 更新时间:2020年10月29日 15:47:44   作者:I like study.  
这篇文章主要为大家详细介绍了Java实现线性表的链式存储,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了Java实现线性表的链式存储,供大家参考,具体内容如下

链表:一种物理存储结构上非连续、非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的。

package algorithm.datastructure.linklist;
import java.util.NoSuchElementException;

/*
* 链表
* 物理存储上非连续的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现
* 
* */
public class LinkedList {
 private Node head;//头节点
 private int size;//链表长度
 static private class Node{
 private int data;
 private Node next;
 public Node(){

 }
 private Node(int data,Node next){
  this.data=data;
  this.next=next;
 }
 }

 //初始化空链表
 public LinkedList(){
 //head=null;
 }

 //添加元素
 public Boolean add(int element){
 linkLast(element);
 return true;
 }
 //在某个位置之前添加元素
 public Boolean add(int index,Integer element){
 checkPositionIndex(index);
 if (index==size){
  linkLast(element);
 } else {
  linkBefore(element,node(index));
 }

 return true;
 }
 //根据下标获取元素
 public int get(int index){
 checkElementIndex(index);
 return node(index).data;
 }
 //获取第一个元素
 public Integer getFirst(){
 Node f=head;
 if (f==null){
  throw new NoSuchElementException();
 } else {
  return f.data;
 }
 }
 //获取最后一个元素
 public Integer getLast(){
 if (size==0){
  throw new NoSuchElementException();
 }
 int index=size-1;
 return node(index).data;
 }

 //删除第一个元素
 public Integer removeFirst(){
 Node f=head;
 if (f==null){
  throw new NoSuchElementException();
 } else {
  return unlink(head);
 }
 }

 //删除最后一个元素
 public Integer removeLast(){
 if (size==0){
  throw new NoSuchElementException();
 }
 int index=size-1;
 return unlink(node(index));
 }


 //根据索引删除元素
 public Integer remove(int index){
 checkElementIndex(index);
 return unlink(node(index));
 }

 //销毁链表
 public void destroyList(){
 clearList();
 }
 //将链表置为空表
 public void clearList() {

 for (Node p=head;p!=null;){
  Node next=p.next;//记录下一个结点
  p=null;//删除当前结点
  p=next;//指向下一个结点
 }
 size=0;
 head=null;
 }
 //遍历链表
 public void traverseList(){

 for (Node p=head;p!=null;){
  System.out.println(p.data);
  p=p.next;
 }
 }

 //返回链表元素个数
 public int size(){
 return size;
 }


 //尾部添加结点
 private void linkLast(int element){
 Node cur =null,p;
 if (size==0){//没有结点时
  head=new Node(element,null);
  size++;
  return;
 }
 for (p=head;p!=null;){//有结点时候
  cur=p;
  p=cur.next;
 }
 cur.next= new Node(element,null);//尾部添加元素
 size++;
 }


 //在某结点之前插入结点
 private void linkBefore(int element,Node node){
 if (node==null){
  linkLast(element);
 } else {
  Node p=head,q=p.next;
  if (node.data==p.data){//node为结点时候
  head= new Node(element, p);//在头部插入元素
  size++;
  } else {
  while (p!=null){
   if (q.data==node.data) {
   p.next= new Node(element,q);//在q之前(p之后)插入一个元素
   size++;
   break;
   }
   p=p.next;
   q=p.next;
  }

  }
 }

 }

 //删除结点
 private Integer unlink(Node node){
 Integer deleteNodeData=null;
 Node p=null;
 deleteNodeData=node.data;
 if (node.data==head.data){//该节点为头结点
  p=head;
  head=p.next;
  p=null;
  size--;
 } else {
  Node q=head;
  for (p=q.next;p!=null;){//使用两个指针,p,q
  if (p.data==node.data){
   break;
  }
  q=q.next;//p始终为q的next结点
  p=q.next;
  }
  q.next=p.next;
  p=null;//删除p
  size--;
 }
 return deleteNodeData;
 }

 //数组下标是否越界
 private Boolean isElementIndex(int index){
 return index>=0&&index<size;
 }
 //插入位置是否越界
 public Boolean isPositionIndex(int index){
 return index>=0&&index<=size;
 }

 //检验下标是否越界,抛出异常
 private void checkElementIndex(int index){
 if(!isElementIndex(index)){
  try {
  throw new IndexOutOfBoundsException("下标越界");
  } catch (Exception e) {
  e.printStackTrace();
  }
 }
 }

 //检验插入下标是否越界,抛出异常
 private void checkPositionIndex(int index){
 if(!isPositionIndex(index)){
  try {
  throw new IndexOutOfBoundsException("下标越界");
  } catch (Exception e) {
  e.printStackTrace();
  }
 }
 }

 //返回指定位置的元素
 private Node node(int index){
 int nowIndex = 0;
 if(size>0){
  for (Node p=head;p!=null;){
  if (nowIndex==index){
   return p;
  }
  p=p.next;
  nowIndex++;
  }
 }
 return null;

 }

 public static void main(String[] args) {


 java.util.LinkedList linkedList0=new java.util.LinkedList();
 linkedList0.add(6);
 linkedList0.remove(0);
 linkedList0.size();
 linkedList0.peek();
 //linkedList0.getFirst();
 linkedList0.clear();

 //测试
 LinkedList linkedList=new LinkedList();
 linkedList.add(2);
 linkedList.add(6);
 linkedList.add(0);
 linkedList.add(3);
 linkedList.add(8);
 linkedList.add(10);
 System.out.println(linkedList.get(0));
 System.out.println(linkedList.getFirst());
 System.out.println(linkedList.getLast());
 System.out.println(linkedList.get(5));
 System.out.println(linkedList.remove(5));
 System.out.println(linkedList.remove(4));

 linkedList.remove(2);
 linkedList.remove(0);
 linkedList.remove(0);
 linkedList.remove(0);

 linkedList.add(2);
 linkedList.add(6);
 linkedList.add(0);
 linkedList.add(3);
 linkedList.add(8);
 linkedList.add(10);

 linkedList.removeFirst();
 linkedList.removeFirst();
 linkedList.removeLast();
 System.out.println(linkedList.size());


 System.out.println("遍历链表");
 linkedList.traverseList();
 linkedList.add(0,4);
 linkedList.add(0,5);
 linkedList.add(2,5);

 linkedList.add(4,5);

 linkedList.add(6,9);
 linkedList.add(8,11);
 linkedList.add(9,222);
 // linkedList.linkBefore(3,new Node(3,null));
// linkedList.linkBefore(3,new Node(2,null));
// linkedList.linkBefore(3,new Node(2,null));
// linkedList.linkBefore(7,new Node(2,null));
// linkedList.linkBefore(9,new Node(7,null));
// linkedList.linkBefore(9,new Node(8,null));
 System.out.println("遍历链表");
 linkedList.traverseList();
 linkedList.clearList();



 }
}

以上就是Java简单实现线性表的链式存储,更多功能可参考Java集合中的LinkedList实现。

相关文章

  • Java线程优先级和守护线程原理解析

    Java线程优先级和守护线程原理解析

    这篇文章主要介绍了Java线程优先级和守护线程原理解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • Mybatis 数据库连接池的实现示例

    Mybatis 数据库连接池的实现示例

    在Java应用程序中,与数据库的连接是非常昂贵的,因此,当我们使用MyBatis进行数据操作时,需要一个连接池来分配并管理这些连接,本文主要介绍了Mybatis 数据库连接池的实现示例,具有一定的参考价值,感兴趣的可以了解一下
    2023-10-10
  • Spring Boot实现qq邮箱验证码注册和登录验证功能

    Spring Boot实现qq邮箱验证码注册和登录验证功能

    这篇文章主要给大家介绍了关于Spring Boot实现qq邮箱验证码注册和登录验证功能的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-12-12
  • 如何从官网下载Hibernate jar包的方法示例

    如何从官网下载Hibernate jar包的方法示例

    这篇文章主要介绍了如何从官网下载Hibernate jar包的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-04-04
  • win10 java(jdk安装)环境变量配置和相关问题

    win10 java(jdk安装)环境变量配置和相关问题

    这篇文章主要介绍了win10java(jdk安装)环境变量配置和相关问题解决,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-12-12
  • Java编程实现提取文章中关键字的方法

    Java编程实现提取文章中关键字的方法

    这篇文章主要介绍了Java编程实现提取文章中关键字的方法,较为详细的分析了Java提取文章关键字的原理与具体实现技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • springcloud feign 接口指定接口服务ip方式

    springcloud feign 接口指定接口服务ip方式

    这篇文章主要介绍了springcloud feign 接口指定接口服务ip方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-03-03
  • Spring MVC文件上传大小和类型限制以及超大文件上传bug问题

    Spring MVC文件上传大小和类型限制以及超大文件上传bug问题

    这篇文章主要介绍了Spring MVC文件上传大小和类型限制以及超大文件上传bug问题,非常具有实用价值,需要的朋友可以参考下
    2017-10-10
  • 简单实现Java通讯录系统

    简单实现Java通讯录系统

    这篇文章主要为大家详细介绍了如何简单实现Java通讯录系统,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-02-02
  • Spring中@Autowired与@Resource的区别详析

    Spring中@Autowired与@Resource的区别详析

    @Autowired与@Resource都可以用来装配bean,都可以写在字段上,或写在setter方法上,下面这篇文章主要给大家介绍了关于Spring中@Autowired与@Resource区别的相关资料,需要的朋友可以参考下
    2021-10-10

最新评论