单链表的实现-JAVA语言
小标 2018-07-19 来源 : 阅读 1034 评论 0

摘要:本文主要向大家介绍了单链表的实现-JAVA语言,通过具体的内容向大家展示,希望对大家学习JAVA语言有所帮助。

本文主要向大家介绍了单链表的实现-JAVA语言,通过具体的内容向大家展示,希望对大家学习JAVA语言有所帮助。

 数据结构还是很重要的,就算不是那种很牛逼的,但起码得知道基础的东西,这一系列就算是复习一下以前学过的数据结构和填补自己在这一块的知识的空缺。加油。珍惜校园中自由学习的时光。按照链表、栈、队列、排序、数组、树这种顺序来学习数据结构这门课程把。

                            -WH

一、单链表的概念

      链表是最基本的数据结构,其存储的你原理图如下图所示

          

      上面展示的是一个单链表的存储原理图,简单易懂,head为头节点,他不存放任何的数据,只是充当一个指向链表中真正存放数据的第一个节点的作用,而每个节点中都有一个next引用,指向下一个节点,就这样一节一节往下面记录,直到最后一个节点,其中的next指向null。

      链表有很多种,比如单链表,双链表等等。我们就对单链表进行学习,其他的懂了原理其实是一样的。

 

二、用java实现单链表

      语言只是一种工具,数据结构真正体会的是那种思想,这句话确实是这样,不管用什么写,其思想是不改变的。以前使用的是C++,现在用的是java,一步步来实现。

      2.1、编写一个Node类来充当结点的模型。我们知道,其中有两个属性,1存放数据的data,2存放下一结点的引用,

          

 View Code

 

      2.2、单链表的简单操作(增加,删除,获取总长度,链表元素排序,链表遍历)  

            

         2.2.1、增加结点操作,addNode(Node)

             

           想法:    一开始也会想如果什么结点也没有。是不是需要判断插入的是第一个结点的问题,但写完后发现没有必要,是不是第一个结点操作都是一样的,所以通过移动的指针遍历整个链表,找到最后一个结点,往后添加即可。没难度。      

 View Code

         2.2.2、插入结点到链表的指定位置。 insertNodeByIndex(int index,Node node)

              

            注意:要知道插入操作需要的前提是什么,你才好写代码,写完之后,考虑如果在特殊位置上插入,是否也一样。还有需要进行插入位置是否可行的判断。

 View Code

 

         2.2.3、删除指定位置上的结点  delNodeByIndex(int index)

              

 View Code

 

          2.2.4、单链表进行选择排序  selectSortNode()  

                前提要知道什么是选择排序,如果不会,请查看我讲解排序的文章

              

              分析

              

 View Code

 

          2.2.5、单链表进行插入排序  insertSortNode()

              前提:要知道什么是插入排序。这个使用插入排序写了我好久,懵逼一样的状态,并且我认为我自己写效率不是很高。不管怎样,是骡子是马拿出来溜溜

              

              

 View Code

    

          2.2.6、当然还可以使用冒泡排序、归并排序,等等等,都可以自己去尝试,我就不写了。如果不懂这些排序,那么就看我写排序的文章把。

          2.2.7、计算单链表的长度

              

 View Code

 

          2.2.8、遍历单链表,打印data

                

 

 View Code

  

三、总结

    基本的单链表操作就是上面这些了,自己完全手动写一写,会对单链表这种数据结构的理解有很大的帮助。当然其中比较难的是在于对链表的排序上,说难也不难,只要懂的几种排序的原理,就跟写伪代码一样,去实现即可。这里还有一些操作,大家可以动手做一做,我会在下一篇文章中讲解这些答案。

    3.1、如何从链表中删除重复数据

    3.2、如何找出单链表中的倒数第k个元素

    3.3、如何实现链表的反转

    3.4、如何从尾到头输出单链表

    3.5、如何寻找单链表的中间结点

    3.6、如何检测一个链表是否有环

    3.7、如何在不知道头结点的情况下删除指定结点

    3.8、如何判断两个链表是否相交

本文由职坐标整理并发布,希望对同学们有所帮助。了解更多详情请关注编程语言JAVA频道!

本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 0 不喜欢 | 0
看完这篇文章有何感觉?已经有0人表态,0%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式IT培训就业服务领导者 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved

208小时内训课程