java链表实现_链表的原理及java实现

一:单向链表基本介绍

链表是一种数据结构,和数组同级。比如,Java中我们使用的ArrayList,其实现原理是数组。而LinkedList的实现原理就是链表了。链表在进行循环遍历时效率不高,但是插入和删除时优势明显。下面对单向链表做一个介绍。

单向链表是一种线性表,实际上是由节点(Node)组成的,一个链表拥有不定数量的节点。其数据在内存中存储是不连续的,它存储的数据分散在内存中,每个结点只能也只有它能知道下一个结点的存储位置。由N各节点(Node)组成单向链表,每一个Node记录本Node的数据及下一个Node。向外暴露的只有一个头节点(Head),我们对链表的所有操作,都是直接或者间接地通过其头节点来进行的。

7fe5e321f23ca6d19c4a5821bc5c2523.png 

上图中最左边的节点即为头结点(Head),但是添加节点的顺序是从右向左的,添加的新节点会被作为新节点。最先添加的节点对下一节点的引用可以为空。引用是引用下一个节点而非下一个节点的对象。因为有着不断的引用,所以头节点就可以操作所有节点了。

下图描述了单向链表存储情况。存储是分散的,每一个节点只要记录下一节点,就把所有数据串了起来,形成了一个单向链表。

efd7e171d0de3af3b256b1cc6f8d7b1b.png 

节点(Node)是由一个需要储存的对象及对下一个节点的引用组成的。也就是说,节点拥有两个成员:储存的对象、对下一个节点的引用。下面图是具体的说明:

e4f112fae7021bb23bd950af121438fe.png

二、单项链表的实现

/***@authorAdministrator*/

public classMyLink {

Node head= null; //头节点

/*** 链表中的节点,data代表节点的值,next是指向下一个节点的引用

*

*@authorzjn

**/

classNode {

Node next= null;//节点的引用,指向下一个节点

int data;//节点的对象,即内容

public Node(intdata) {this.data =data;

}

}/*** 向链表中插入数据

*

*@paramd*/

public void addNode(intd) {

Node newNode= new Node(d);//实例化一个节点

if (head == null) {

head=newNode;return;

}

Node tmp=head;while (tmp.next != null) {

tmp=tmp.next;

}

tmp.next=newNode;

}/***

*@paramindex:删除第index个节点

*@return

*/

public boolean deleteNode(intindex) {if (index < 1 || index >length()) {return false;

}if (index == 1) {

head=head.next;return true;

}int i = 1;

Node preNode=head;

Node curNode=preNode.next;while (curNode != null) {if (i ==index) {

preNode.next=curNode.next;return true;

}

preNode=curNode;

curNode=curNode.next;

i++;

}return false;

}/***

*@return返回节点长度*/

public intlength() {int length = 0;

Node tmp=head;while (tmp != null) {

length++;

tmp=tmp.next;

}returnlength;

}/*** 在不知道头指针的情况下删除指定节点

*

*@paramn

*@return

*/

public booleandeleteNode11(Node n) {if (n == null || n.next == null) {return false;

}int tmp =n.data;

n.data=n.next.data;

n.next.data=tmp;

n.next=n.next.next;

System.out.println("删除成功!");return true;

}public voidprintList() {

Node tmp=head;while (tmp != null) {

System.out.println(tmp.data);

tmp=tmp.next;

}

}public static voidmain(String[] args) {

MyLink list= newMyLink();

list.addNode(5);

list.addNode(3);

list.addNode(1);

list.addNode(2);

list.addNode(55);

list.addNode(36);

System.out.println("linkLength:" +list.length());

System.out.println("head.data:" +list.head.data);

list.printList();

list.deleteNode(4);

System.out.println("After deleteNode(4):");

list.printList();

}

}

三、链表相关的常用操作实现方法

1. 链表反转

/*** 链表反转

*

*@paramhead

*@return

*/

publicNode ReverseIteratively(Node head) {

Node pReversedHead=head;

Node pNode=head;

Node pPrev= null;while (pNode != null) {

Node pNext=pNode.next;if (pNext == null) {

pReversedHead=pNode;

}

pNode.next=pPrev;

pPrev=pNode;

pNode=pNext;

}this.head =pReversedHead;return this.head;

}

2. 查找单链表的中间节点

采用快慢指针的方式查找单链表的中间节点,快指针一次走两步,慢指针一次走一步,当快指针走完时,慢指针刚好到达中间节点。

/*** 查找单链表的中间节点

*

*@paramhead

*@return

*/

publicNode SearchMid(Node head) {

Node p= this.head, q = this.head;while (p != null && p.next != null && p.next.next != null) {

p=p.next.next;

q=q.next;

}

System.out.println("Mid:" +q.data);returnq;

}

3. 查找倒数第k个元素

采用两个指针P1,P2,P1先前移K步,然后P1、P2同时移动,当p1移动到尾部时,P2所指位置的元素即倒数第k个元素 。

/*** 查找倒数 第k个元素

*

*@paramhead

*@paramk

*@return

*/

public Node findElem(Node head, intk) {if (k < 1 || k > this.length()) {return null;

}

Node p1=head;

Node p2=head;for (int i = 0; i < k; i++)//前移k步

p1 =p1.next;while (p1 != null) {

p1=p1.next;

p2=p2.next;

}returnp2;

}

4. 对链表进行排序

/*** 排序

*

*@return

*/

publicNode orderList() {

Node nextNode= null;int tmp = 0;

Node curNode=head;while (curNode.next != null) {

nextNode=curNode.next;while (nextNode != null) {if (curNode.data >nextNode.data) {

tmp=curNode.data;

curNode.data=nextNode.data;

nextNode.data=tmp;

}

nextNode=nextNode.next;

}

curNode=curNode.next;

}returnhead;

}

5. 删除链表中的重复节点

/*** 删除重复节点*/

public voiddeleteDuplecate(Node head) {

Node p=head;while (p != null) {

Node q=p;while (q.next != null) {if (p.data ==q.next.data) {

q.next=q.next.next;

}elseq=q.next;

}

p=p.next;

}

}

6. 从尾到头输出单链表,采用递归方式实现

/*** 从尾到头输出单链表,采用递归方式实现

*

*@parampListHead*/

public voidprintListReversely(Node pListHead) {if (pListHead != null) {

printListReversely(pListHead.next);

System.out.println("printListReversely:" +pListHead.data);

}

}

7. 判断链表是否有环,有环情况下找出环的入口节点

/*** 判断链表是否有环,单向链表有环时,尾节点相同

*

*@paramhead

*@return

*/

public booleanIsLoop(Node head) {

Node fast= head, slow =head;if (fast == null) {return false;

}while (fast != null && fast.next != null) {

fast=fast.next.next;

slow=slow.next;if (fast ==slow) {

System.out.println("该链表有环");return true;

}

}return !(fast == null || fast.next == null);

}/*** 找出链表环的入口

*

*@paramhead

*@return

*/

publicNode FindLoopPort(Node head) {

Node fast= head, slow =head;while (fast != null && fast.next != null) {

slow=slow.next;

fast=fast.next.next;if (slow ==fast)break;

}if (fast == null || fast.next == null)return null;

slow=head;while (slow !=fast) {

slow=slow.next;

fast=fast.next;

}returnslow;

}

转载自:https://blog.csdn.net/jianyuerensheng/article/details/51200274

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/259682.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

xss challenge 解题思路(1-3)

challenge1: 用很基本的方法即可&#xff0c;截图如下&#xff1a; 提交后成功弹窗&#xff0c;完成。 challenge2 这次我们发现我们输入的内容被放入value”“ 中&#xff0c;所以需要将前面的结构闭合&#xff0c;构造如下&#xff1a; "><script>alert(docume…

宾得准饼干广角镜头DA15

DA15的挂机效果图&#xff0c;感觉还是超级的小&#xff0c;是最小的广角镜头了&#xff1a; 主要特点1. 超广视角当安装在宾得数码单反相机上时&#xff0c;这款全新的镜头提供相当于35mm胶片规格的约23mm画面视角&#xff0c;可使拍摄者拍摄出独特的诱人影像和超广角镜头独有…

java slf4j_SLF4J 使用手册

原文链接 译者&#xff1a;zivyuJava的简单日志门面( Simple Logging Facade for Java SLF4J)作为一个简单的门面或抽象&#xff0c;用来服务于各种各样的日志框架&#xff0c;比如java.util.logging、logback和log4j。SLF4J允许最终用户在部署时集成自己想要的日志框架。需要…

[译]Java 垃圾回收介绍

说明&#xff1a;这篇文章来翻译来自于Javapapers 的Java Garbage Collection Introduction 在Java中&#xff0c;对象内存空间的分配与回收是由JVM中的垃圾回收进程自动完成的。和C语言不一样的是&#xff0c;开发中不需要在Java中写垃圾回收代码。这也是使Java更加流行而且帮…

打印三角形

直角三角形 #include<iostream> using namespace std; int main() { int i,j; for(i1;i<10;i) {for(j1;j<i;j) cout<<"*"; cout<<endl; } } ———————————————————————————…

Linux基础入门学习笔记之二

第三节 用户及文件权限管理 Linux用户管理 Linux是可以实现多用户登录的操作系统 查看用户who命令用于查看用户 shiyanlou是当前登录用户的用户名 pts/0中pts表示伪终端&#xff0c;后面的数字表示伪终端的序号。 后面是当前伪终端启动时间 创建用户创建用户需要root权限&#…

这几天有django和python做了一个多用户博客系统(可选择模板) 没完成,先分享下...

这个TBlog已经全新改版了&#xff0c;更名为UUBlog 新版地址&#xff1a; 用Python和Django实现多用户博客系统——UUBlog 断断续续2周时间吧&#xff0c;用django做了一个多用户博客系统&#xff0c;现在还没有做完&#xff0c;做分享下,以后等完善了再慢慢说 做的时候房展了博…

MySQL数据高级查询之连接查询、联合查询、子查询

2019独角兽企业重金招聘Python工程师标准>>> 一、连接查询 连接查询: 将多张表(>2)进行记录的连接(按照某个指定的条件进行数据拼接)。 连接查询的意义: 在用户查看数据的时候,需要显示的数据来自多张表. 连接查询: join, 使用方式: 左表 join 右表&#xff1b;左…

Oracle11g解锁报错SP2-0306-选项无效

普通用户登录isqlplus: (一)在浏览器中输入URL &#xff08;http://localhost:5560/isqlplus&#xff09;。显示登录界面 这里只能用普通用户进行登录&#xff0c;因为要用sys登录&#xff0c;必须用sys的DBA身份登录。所以用普通用户SCOTT&#xff0c;但是还未解锁 问题:SP2-0…

Chrome浏览器无法观看视频,一直提示“adobe flash player 已过期” ?

很多新用户在安装了Chrome浏览器或者更新过的的时候&#xff0c;经常提示“ adobe flash player 已过期”的问题&#xff0c;反复提示&#xff0c;导致无法观看视频。于是从网上也找了很多办法都没有解决。这里给大家提供一个最完美的解决方案。经亲自测试&#xff0c;完美解决…

关于JVM的垃圾回收GC的一些记录

目录 一、JVM内存区域划分 二、从一个基本问题开始引入垃圾回收 三、GC作用的区域 三、如何确定一个对象是否可以被当成垃圾进行回收 &#xff08;1&#xff09;引用计数法 &#xff08;2&#xff09;可达性分析算法 &#xff08;3&#xff09;引用的类型 &#xff08;3…

codevs1219 骑士遍历(棋盘DP)

题目描述 Description设有一个n*m的棋盘&#xff08;2≤n≤50&#xff0c;2≤m≤50&#xff09;&#xff0c;如下图&#xff0c;在棋盘上有一个中国象棋马。 规定&#xff1a; 1)马只能走日字 2)马只能向右跳 问给定起点x1,y1和终点x2,y2&#xff0c;求出马从x1,y1出发到x2,y2的…

java ssh免密登录_SSH公钥、私钥配置(SSH免密码登录方式)

1.首先使用想要发起ssh免密访问的用户A登录Linux(简称客户端Linux)2.进入该用户的家目录(cd ~)&#xff0c;看是否有.ssh文件夹(linux中以.开头文件夹是隐藏的&#xff0c;使用ll -a进行查看)&#xff0c;如果没有则创建(mkdir ~/.ssh)&#xff0c;并修改访问权限(chmod 700 ~…

win8, VS2013 .NET 4.5在哪找svcutil.exe?

我这个纠结呀&#xff0c;公司用win8&#xff0c; .NET 4.5。想做一个很简单的项目&#xff0c;就是wcf宿主iis&#xff0c;项目根目录下有aspx文件和svc文件。于是参考了一个博客http://www.cnblogs.com/yjmyzz/archive/2008/08/19/1270961.html&#xff0c;[原创]WCF入门级使…

Starling 2D框架简介

本系列是对Introducing Starling pdf的翻译&#xff0c;下文是对adobe开发人员中心的一片日志的转载&#xff0c;地址为http://www.adobe.com/cn/devnet/flashplayer/articles/introducing_Starling.html Starling 是在 Stage3D APIs 基础上开发的一种 ActionScript 3 2D 框架&…

Android AutoCompleteTextView控件实现类似百度搜索提示,限制输入数字长度

Android AutoCompleteTextView 控件实现类似被搜索提示&#xff0c;效果如下 1.首先贴出布局代码 activity_main.xml&#xff1a; <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas.android.com/apk/res…

java即时聊天系统毕业_(完整版)基于Java即时聊天系统的设计与实现毕业论文设计...

目录1 前言...................................................................................................................................1.1 课题选题背景...................................................................................................…

java与算法_Java与算法之(1) - 冒泡排序

冒泡排序法的原理是&#xff0c;每次比较相邻的两个元素&#xff0c;如果它们的顺序错误就把它们交换过来。例如对4 3 6 2 7 1 5这7个数字进行从小到大的排序&#xff0c;从最左侧开始&#xff0c;首先比较4和3因为是从小到大排序&#xff0c;4和3的顺序显然是错误的&#xff0…

JQuery链式操作简单的菜单列表

看到这个简单的菜单demo&#xff0c;也是为了再看看JQuery对DOM的操作&#xff0c;一直都记不牢&#xff0c;特别是siblings&#xff08;&#xff09;这个总是想不起来。 这次再过一遍JQuery&#xff0c;不管简单的还是复杂的demo 还是坚持练习一遍吧&#xff01;只为记录&…

利用JS实现点击上一周或下一周却换

1.页面加载显示当前年份的第几周 效果如图&#xff1a; html代码&#xff1a; <font size"2" color"black"> <input id"btnweek5" type"button" class"btn" value"上周" οnclick"EduCommissio…