java链表数据结构是什么_java 链表数据结构

java链表数据结构是什么_java 链表数据结构首先,单链表相对于队列的优势在于存储地址不是连续的,这样的意义在于,操作其中的某一个位置的元素时不需要对之前的其他元素都进行内存操作,大大的为我们的计算机减压了。下面直接进入正题:先要定义一个结点类,如下:Java代码publicclassNode{Nodenext;//下一个结点的引用Objectobj;//结点元素publicNode(Objectobj){this.obj=obj;…

大家好,又见面了,我是你们的朋友全栈君。

首先,单链表相对于队列的优势在于存储地址不是连续的,这样的意义在于,操作其中的某一个位置的元素时不需要对之前的其他元素都进行内存操作,大大的为我们的计算机减压了。下面直接进入正题:

先要定义一个结点类,如下:

Java代码

public classNode {

Node next;//下一个结点的引用

Object obj;//结点元素

publicNode(Object obj){this.obj=obj;

}

}

然后就是我们的LinkedList类,先要定义一个空链表:

Node head=null;//创建一个空链表,头结点

Node last=head;//尾结点

打印链表有两种方法,可以采用递归,也可以使用非递归的方法,如下:

Java代码

/*** 非递归打印元素的方法*/

public voidprint(Node head){while(head!=null){

System.out.println(head.obj);

head=head.next;//索引向后移位

}

}/*** 递归打印链表元素的方法*/

public voidprintNode(Node head){if(head!=null){

System.out.println(head.obj);

Node node=head.next;

printNode(node);//递归调用

}

}

非递归方法有一个致命的缺陷,打印的同时改变了头结点的位置,所以我们应该倾向于使用递归方法。

说了这么多,增删查改正式开始:

向链表中添加元素。判断一个链表已经到达末尾的依据是该结点的next引用已经为Null,所以要向末尾添加一个结点,先要把新增结点放在最后,再把末尾结点向后移位,具体操作过程如下图:

1T5423N9-0.jpg

代码如下:

Java代码

/*** 向指定链表添加元素的方法

*@paramobj 插入的元素*/

public voidadd(Object obj){

Node node=new Node(obj);//新建结点

if(head==null){//如果链表为空

head =node;

}else{

last.next=node;//先把新增结点放在最后

}

last=node;//再把最后一个结点向后移位

}

插入元素。要插入一个新元素首先要创建一个新结点来存放它,而在具体实现的时候最让人头疼的时候无疑是怎样找到指定位置的索引了,这里所说的方法在下面的其他操作基本上都是这样衍生的,先了解一下插入结点的具体实现,根据这个结构的逻辑定义,如果我们要在结点A之后插入一个结点,那么就还需要修改结点A的next引用,实际上就是让A结点的next引用指向新增结点的元素域,然后再让新增结点的next引用指向A原本next结点(B)的元素域,用图来表示更加直观:

1T542A96-1.jpg

代码如下:

Java代码

/*** 向链表中插入新元素的方法*/

public void insert(intindex,Object obj){

Node node=head;int j=0;while(node!=null&&j

node=node.next;

j++;

}

Node sert=new Node(obj);//被插入的结点

sert.next=node.next;

node.next=sert;

}

删除元素。知道了插入元素的具体操作之后,删除元素就显得相对简单了,比如说我们要删除一个结点b,就是要使这个结点失去引用,但是注意不要直接写b=b.next,这样的话b的引用还是存在,而且还会出现另一种错误,大家可以自己试一下,如图所示,正确的删除结点的方法如下:

1T54220Y-2.jpg

代码如下:

Java代码

/*** 删除指定位置的结点

*@paramindex 索引*/

public void delete(intindex){

Node node=head;int j=0;while(node!=null&&j

node=node.next;

j++;

}

node.next=node.next.next;//删除第index个元素

}

最后就是修改元素了。相信大家看完之前的两个方法,接下来的这个方法在心中早就已经泛起波澜了吧,那下面就直接贴代码了:

Java代码

/*** 改变指定位置的元素

*@paramindex 索引

*@paramobj*/

public void modify(intindex,Object obj){

Node node=head;int j=0;while(node!=null&&j

node=node.next;

j++;

}

node.obj=obj;

}

当然,除了这些基本操作,我们还可以写获取链表长度的方法,获取指定位置的元素的方法等等

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/140527.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月27日 下午8:40
下一篇 2022年5月27日 下午8:40


相关推荐

  • SVN 在线代码托管工具

    SVN 在线代码托管工具在互联网环境使用 SVN 服务 你必须要有一台在互联网环境内支持 SVN 服务的在线服务器 OnlineServer 您可能习惯了在公司的内网使用 SVN 但如果您经常于游走于各种不同的办公环境 比如公司 家里 客户处 用着很多台不同的电脑 那么您将需要一台互联网环境的 SVN 服务器 下面介绍几款 SVN 在线代码托管工具 RiouxSVN nbsp 私有 免费 国外 特点 RiouxSVNisfr and

    2026年3月16日
    2
  • java中applet是什么意思_Java Applet与Java Application的区别

    java中applet是什么意思_Java Applet与Java Application的区别在Java语言中,能够独立运行的程序称为Java应用程序(Application)。Java语言还有另外一种程序–Applet程序。Applet程序(也称Java小程序)是运行于各种网页文件中,用于增强网页的人机交互、动画显示、声音播放等功能的程序。JavaApplet和JavaApplication在结构方面的主要区别表现在:(1)运行方式不同。JavaApplet程序不能单独运行,它必…

    2022年7月8日
    24
  • VSCode中的git使用篇

    VSCode中的git使用篇基本上使用在一个目录下 clone 项目 gitcloneXXXX git 使用 VScode 打开项目右击通过 Code 打开 使用 vscode 提交代码打开下面视图 添加一行文字测试提交点击 相当于 gitadd 点击对号 等于 gitcommit m 备注信息 右边的箭头输入需要备注的信息 然后按 Enter 确定 回车之后 然后我们可以看到 所有的

    2026年3月26日
    1
  • oracle存储过程捕捉异常后回滚_Oracle存储过程异常

    oracle存储过程捕捉异常后回滚_Oracle存储过程异常由三种方式抛出异常1.通过PL/SQL运行时引擎2.使用RAISE语句3.调用RAISE_APPLICATION_ERROR存储过程当数据库或PL/SQL在运行时发生错误时,一个异常被PL/SQL运行时引擎自动抛出。异常也可以通过RAISE语句抛出RAISEexception_name;显式抛出异常是程序员处理声明的异常的习惯用法,但RAISE不限于声明了的异常,它可以抛出任何任何异常。例…

    2022年7月17日
    17
  • JxBrowser的概述与简单应用

    JxBrowser的概述与简单应用Q JxBrowser 是什么 JxBrowser 是一个跨平台的 Java 库 允许将基于 GoogleChromi 的 Web 浏览器组件集成到 JavaSwing AWT JavaFX 应用程序中 使用 JxBrowser 您可以将轻量级 Swing JavaFX 组件嵌入到 Java 应用程序中 以显示现代网页 支持最新的 Web 标准 如 HTML5 CSS3 JavaScript 等 Q 为什么

    2026年3月26日
    2
  • 【软考】专栏导读(软考全面介绍、资格报考建议)

    【软考】专栏导读(软考全面介绍、资格报考建议)软考 专栏导读 通过这篇文章带领大家进一步认识软考

    2026年3月19日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号