博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JAVA单向链表实现
阅读量:6251 次
发布时间:2019-06-22

本文共 1636 字,大约阅读时间需要 5 分钟。

JAVA单向链表实现

单向链表

链表和数组一样是一种最常用的线性数据结构,两者各有优缺点。数组我们知道是在内存上的一块连续的空间构成,所以其元素访问可以通过下标进行,随机访问速度很快,但数组也有其缺点,由于数组的内存是一次性申请的,就像基本数据类型一样,一次性申请所需的空间,在数据量变动很大的时候就容易导致预先申请的内存不够或内存浪费。在者就是在存的是有序数列时进行数据插入会比较麻烦,所以链表就是为了弥补数组的不足的一种数据结构。相反的,链表对于变动很大的数据有很大的适应性,而且其对于数据插入和删除很方便。而链表的缺点就是对于内存的浪费,链表除了存储需要的数据还要存储额外的指针。链表的节点示意图如下:

 

看到指针你可能会想:“我们这不是java语言吗?没有指针啊!”,没错!在我对java了解不是很深的时候我也这么想,但是我要说的是java虽然不允许程序员像c/c++那样使用指针,但java语言本身的实现还是离不开指针的(变量名其实就是指向jvm中一块内存的指针,我就不详述)。请看以下节点的代码:

//节点数据结构     private class Node{
private Object data=null;//数据域 private Node next=null;//下一个节点 private Node(Object data) { this.data=data; } }

这里的节点class我是写成inner class的形式,后面有完整代码。还有一点就是这里object类型,这里也可以使用泛型

//链表数据结构 public class SingleLinkList {
int size=0;//链表长度,可有可无,有的话很容易实现很多链表的特殊操作 Node head=null;//头节点 public SingleLinkList() { this.size=0;this.head=null; } }

有了这两个类,然后再来实现链表的一些基本操作:插入头节点,删除头节点,删除指定节点,查找指定节点。直接看完整源代码。

package singleLinkList; ​ public class SingleLinkList {
​ int size=0;//链表长度 Node head=null; public SingleLinkList() { this.size=0;this.head=null; } //节点数据结构 private class Node{ private Object data=null;//数据域 private Node next=null;//下一个节点 private Node(Object data) { this.data=data; } } //表头添加元素 public Object addHead(Object data) { Node newHead=new Node(data); if(size==0) { this.head=newHead; } else { newHead.next=this.head; this.head=newHead; } size++; return data; } //删除表头元素 public Object deleteHead() { if(size>0) { Node node=this.head; this.head=this.head.next; size--; } return null; } //查找指定元素 public Node findData(Object data) { if(size==0)return null; Node cur=this.head;

转载于:https://www.cnblogs.com/Davidhwj/p/10433387.html

你可能感兴趣的文章
做了几道简单的基础题,慢慢熟悉循环
查看>>
元素的多种延时等待(&页面的超时处理)
查看>>
ios 后台发送邮件之SKPSMTPMessage的使用
查看>>
JavaScript学习
查看>>
3014C语言_运算符
查看>>
202702算法_二分法查找
查看>>
Win10 UWP开发实现Bing翻译
查看>>
各种不同类型的类
查看>>
mvc4 -@Html.Partial,@Html.RenderPartial
查看>>
windows2012 r2 提高网速方法
查看>>
调试R代码中出现的常用的函数
查看>>
JavaWeb 之 AJAX
查看>>
十、spark graphx的scala示例
查看>>
探秘SpringAop(一)_介绍以及使用详解
查看>>
查询指定时间内审核失败的事件日志
查看>>
problem-solving-with-algorithms-and-data-structure-usingpython(使用python解决算法和数据结构) -- 算法分析...
查看>>
springmvc流程
查看>>
BAT涉足汽车产业后对汽车后市场的影响是什么?
查看>>
LeetCode:Remove Nth Node From End of List
查看>>
删除链表的第 n 个结点
查看>>