iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >链表原理及java实现的示例分析
  • 308
分享到

链表原理及java实现的示例分析

java 2023-05-30 21:05:10 308人浏览 泡泡鱼
摘要

这篇文章主要介绍了链表原理及java实现的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一:单向链表基本介绍链表是一种数据结构,和数组同级。比如,Java中我们使用的

这篇文章主要介绍了链表原理及java实现的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

一:单向链表基本介绍

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

单链表的概念

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

链表原理及java实现的示例分析

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

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

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

链表原理及java实现的示例分析

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

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

链表原理及java实现的示例分析

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

链表原理及java实现的示例分析

二、单项链表的实现

package com.zjn.LinkAndQueue;public class MyLink {Node head = null;// 头节点class Node {Node next = null;// 节点的引用,指向下一个节点int data;// 节点的对象,即内容public Node(int data) {this.data = data;}}public void addNode(int d) {Node newNode = new Node(d);// 实例化一个节点if (head == null) {head = newNode;return;}Node tmp = head;while (tmp.next != null) {tmp = tmp.next;}tmp.next = newNode;}public Boolean deleteNode(int index) {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;}public int length() {int length = 0;Node tmp = head;while (tmp != null) {length++;tmp = tmp.next;}return length;}public Boolean deleteNode11(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 void printList() {Node tmp = head;while (tmp != null) {System.out.println(tmp.data);tmp = tmp.next;}}public static void main(String[] args) {MyLink list = new MyLink();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();}}

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

链表反转

  public Node 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;  }

查找单链表的中间节点

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

  public Node 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);    return q;  }

查找倒数第k个元素

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

  public Node findElem(Node head, int k) {    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;    }    return p2;  }

对链表进行排序

public Node 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;}return head;}

删除链表中的重复节点

  public void deleteDuplecate(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;        } else          q = q.next;      }      p = p.next;    }  }

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

  public void printListReversely(Node pListHead) {    if (pListHead != null) {      printListReversely(pListHead.next);      System.out.println("printListReversely:" + pListHead.data);    }  }

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

  public boolean IsLoop(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);  }    public Node 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;    }    return slow;  }

感谢你能够认真阅读完这篇文章,希望小编分享的“链表原理及java实现的示例分析”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网精选频道,更多相关知识等着你来学习!

--结束END--

本文标题: 链表原理及java实现的示例分析

本文链接: https://www.lsjlt.com/news/221206.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 链表原理及java实现的示例分析
    这篇文章主要介绍了链表原理及java实现的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一:单向链表基本介绍链表是一种数据结构,和数组同级。比如,Java中我们使用的...
    99+
    2023-05-30
    java
  • Java中链表的示例分析
    这篇文章将为大家详细讲解有关Java中链表的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。题目一 解法class Solution {  &nbs...
    99+
    2023-06-29
  • Java链表实例分析
    这篇文章主要介绍了Java链表实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Java链表实例分析文章都会有所收获,下面我们一起来看看吧。1、删除值为val的所有节点删除链表中等于给定值val的所有节点。...
    99+
    2023-06-29
  • Java复杂链表的示例分析
    这篇文章将为大家详细讲解有关Java复杂链表的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1.题目请实现 copyRandomList 函数,复制一个复杂链表。在复杂链表中,每个节点除了有一个 ...
    99+
    2023-06-28
  • leetcode链表之分割链表的示例分析
    这篇文章主要介绍了leetcode链表之分割链表的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。题目编写程序以 x 为基准分割链表,使得所有小于&...
    99+
    2023-06-19
  • Java之单链表问题的示例分析
    这篇文章给大家分享的是有关Java之单链表问题的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。单链表单链表是一种链式存取的数据结构,用一组地址任意的存储单元存放线性表中的数据元素。链表中的数据是以结点来表...
    99+
    2023-06-20
  • CSS中链接以及列表的示例分析
    这篇文章主要介绍CSS中链接以及列表的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!   a:link{   color:cornflowerblue;   text-...
    99+
    2024-04-02
  • MySQL分区表原理的示例分析
    这篇文章主要为大家展示了“MySQL分区表原理的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“MySQL分区表原理的示例分析”这篇文章吧。1、分区表含义...
    99+
    2024-04-02
  • TF-IDF理解及其Java实现的示例分析
    这篇文章将为大家详细讲解有关TF-IDF理解及其Java实现的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。TF-IDF前言前段时间,又具体看了自己以前整理的TF-IDF,这里把它发布在博客上,知...
    99+
    2023-05-30
    tf-idf算法 java
  • java 相交链表的实现示例
    目录1.题目2.分析3.完整代码1.题目 相交链表:给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null...
    99+
    2024-04-02
  • Spring AOP实现原理的示例分析
    这篇文章将为大家详细讲解有关Spring AOP实现原理的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。什么是AOPAOP(Aspect-OrientedProgramming,面向方面编程),可...
    99+
    2023-05-30
    spring aop
  • vue-router实现原理的示例分析
    这篇文章将为大家详细讲解有关vue-router实现原理的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。大致流程可以看成这样:浏览器发出请求服务器监听到80端口(...
    99+
    2024-04-02
  • php中链表的示例分析
    这篇文章将为大家详细讲解有关php中链表的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。链表的操作相对顺序表来说就复杂了许多。因为PHP确实已经为我们解决了很多数组操作上的问题,所以我们可以很方便...
    99+
    2023-06-20
  • Redis中链表的示例分析
    这篇文章主要介绍Redis中链表的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1 链表和链表节点的结构1 节点结构节点的结构大概长下边这个样子:那么,把这些节点就连起来就成了这个样子:2 链表结构链表自然除...
    99+
    2023-06-22
  • java LockSupport实现原理示例解析
    目录引言LockSupport常见函数LockSupport.parkLockSupport.unpark引言 前文中了解到AQS借助LockSupport.park和LockSup...
    99+
    2023-01-09
    java LockSupport原理 java LockSupport
  • 基于红黑树插入操作原理及java实现的示例分析
    这篇文章主要介绍基于红黑树插入操作原理及java实现的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!红黑树是一种二叉平衡查找树,每个结点上有一个存储位来表示结点的颜色,可以是RED或BLACK。红黑树具有以下...
    99+
    2023-05-30
    java
  • Java数据结构之链表的示例分析
    小编给大家分享一下Java数据结构之链表的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一、链表的介绍什么是链表链表是一种物理存储单元上非连续、非顺序的存...
    99+
    2023-06-15
  • React Fiber 链表操作及原理示例详解
    目录正文什么是FiberFiber节点React源码Fiber树是链表节点独立节省操作时间与单向操作利于双缓存与异步可中断更新操作异步可中断更新双缓存正文 看了React源码之后相信...
    99+
    2022-11-13
    React Fiber 链表操作 React Fiber
  • java中Builder原理的示例分析
    这篇文章主要为大家展示了“java中Builder原理的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“java中Builder原理的示例分析”这篇文章吧。首先给一个简单的Builder设...
    99+
    2023-06-22
  • Ajax原理及使用的示例分析
    这篇文章给大家分享的是有关Ajax原理及使用的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。   Ajax原理   AJAX即“Asynchronous Javasc...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作