Java实现实现单链表反转及求中间结点

2023-12-28 16:58

本文主要是介绍Java实现实现单链表反转及求中间结点,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

package task1;/*** 功能:实现单链表反转* Created by liumao 2019/8/5**/
public class ReverseLinkedList {static class Node{private int data;private Node next;public Node(int data, Node next) {this.data = data;this.next = next;}public int getData() {return data;}// 生成一个新的结点public static Node createNode(int value) {return new Node(value,null);}/*** 功能:单链表反转  1234   4321* 若存在没有遍历完的结点,头指针就向后移动,继续遍历* @param  list 反转链表*/public static Node reverse(Node list) {//定义头结点Node headNode = null;//定义尾指针Node preNode = null;//指向list链表Node currentNode = list;//如果指针指向的链表不为空while (currentNode != null) {//先将指针指向的结点中存储的下一个结点地址存储到nextNode中Node nextNode = currentNode.next;//判断指针指向该结点是否有结点,若null,则指针处于链表的最后一位,该结点的最后一位结点为null,即没有结点if (nextNode == null) {//如果是最后一个结点,则把它作为反转链表的头结点headNode = currentNode;}//将反转后的链表地址存储到在单链表拆解下来的结点地址域中currentNode.next = preNode;//尾结点向前移动一个结点preNode = currentNode;//头指针向后移动currentNode = nextNode;}return headNode;}/*** 功能:单链表的合并* @param node1:链表 node1* @param node2:链表 node2* @return*/public static Node mergeSortedLists(Node node1, Node node2) {//判断两个单链表是否为nullif (node1 == null) return node2;if (node2 == null) return node1;//分别将两个链表赋值给 p、qNode p = node1;Node q = node2;//定义一个头结点Node head;//比较两个结点数据域中元素的大小if (p.data < q.data) {//如果  p 数据小于 q 数据,将 p 结点赋值给headhead = p;//数据小的那条链表的指针向后移动一位p = p.next;} else {//否则,移动另一个指针head = q;q = q.next;}//将 head 结点赋值给 rNode r = head;//判断两个链表指针指到最后一个结点,要想跳出循环,肯定p、q其中有一个先遍历完while (p != null && q != null) {//如果没有指到最后的结点,继续进行比较大小if (p.data < q.data) {//r 继承着 head 继续向下添加结点r.next = p;p = p.next;} else {r.next = q;q = q.next;}//r 指针向下移动,指向新添加的结点r = r.next;}//判断 p、q 两个链表哪一个先遍历完,最后将剩余的链表拼接合成到链表的最后if (p != null) {r.next = p;} else {r.next = q;}//返回头结点return head;}}/*** 功能:求中间结点* 思路:定义一个指针 fast 用来移动做逻辑判断* @param list:传入要求中间结点的链表* @return*/public static Node findMiddleNode(Node list) {//如果单链表为 null,就返回 nullif (list == null) return null;//slow 指向的就是 fast.next 与 fast.next.next 中间的那个结点Node fast = list;Node slow = list;//循环遍历满足fast指针条件单链表while (fast.next != null && fast.next.next != null) {fast = fast.next.next;slow = slow.next;}//返回的slow就是中间结点return slow;}//输入链表的所有值public static void printAll(Node list) {Node p = list;while (p != null) {System.out.print(p.data + " ");p = p.next;}System.out.println();}
}

这篇关于Java实现实现单链表反转及求中间结点的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/546621

相关文章

C#高效实现在Word文档中自动化创建图表的可视化方案

《C#高效实现在Word文档中自动化创建图表的可视化方案》本文将深入探讨如何利用C#,结合一款功能强大的第三方库,实现在Word文档中自动化创建图表,为你的数据呈现和报告生成提供一套实用且高效的解决方... 目录Word文档图表自动化:为什么选择C#?从零开始:C#实现Word文档图表的基本步骤深度优化:C

SpringBoot整合AOP及使用案例实战

《SpringBoot整合AOP及使用案例实战》本文详细介绍了SpringAOP中的切入点表达式,重点讲解了execution表达式的语法和用法,通过案例实战,展示了AOP的基本使用、结合自定义注解以... 目录一、 引入依赖二、切入点表达式详解三、案例实战1. AOP基本使用2. AOP结合自定义注解3.

nginx跨域访问配置的几种方法实现

《nginx跨域访问配置的几种方法实现》本文详细介绍了Nginx跨域配置方法,包括基本配置、只允许指定域名、携带Cookie的跨域、动态设置允许的Origin、支持不同路径的跨域控制、静态资源跨域以及... 目录一、基本跨域配置二、只允许指定域名跨域三、完整示例四、配置后重载 nginx五、注意事项六、支持

Qt实现对Word网页的读取功能

《Qt实现对Word网页的读取功能》文章介绍了几种在Qt中实现Word文档(.docx/.doc)读写功能的方法,包括基于QAxObject的COM接口调用、DOCX模板替换及跨平台解决方案,重点讨论... 目录1. 核心实现方式2. 基于QAxObject的COM接口调用(Windows专用)2.1 环境

MySQL查看表的历史SQL的几种实现方法

《MySQL查看表的历史SQL的几种实现方法》:本文主要介绍多种查看MySQL表历史SQL的方法,包括通用查询日志、慢查询日志、performance_schema、binlog、第三方工具等,并... 目录mysql 查看某张表的历史SQL1.查看MySQL通用查询日志(需提前开启)2.查看慢查询日志3.

Java实现字符串大小写转换的常用方法

《Java实现字符串大小写转换的常用方法》在Java中,字符串大小写转换是文本处理的核心操作之一,Java提供了多种灵活的方式来实现大小写转换,适用于不同场景和需求,本文将全面解析大小写转换的各种方法... 目录前言核心转换方法1.String类的基础方法2. 考虑区域设置的转换3. 字符级别的转换高级转换

使用Python实现局域网远程监控电脑屏幕的方法

《使用Python实现局域网远程监控电脑屏幕的方法》文章介绍了两种使用Python在局域网内实现远程监控电脑屏幕的方法,方法一使用mss和socket,方法二使用PyAutoGUI和Flask,每种方... 目录方法一:使用mss和socket实现屏幕共享服务端(被监控端)客户端(监控端)方法二:使用PyA

MyBatis-Plus逻辑删除实现过程

《MyBatis-Plus逻辑删除实现过程》本文介绍了MyBatis-Plus如何实现逻辑删除功能,包括自动填充字段、配置与实现步骤、常见应用场景,并展示了如何使用remove方法进行逻辑删除,逻辑删... 目录1. 逻辑删除的必要性编程1.1 逻辑删除的定义1.2 逻辑删php除的优点1.3 适用场景2.

SpringBoot简单整合ElasticSearch实践

《SpringBoot简单整合ElasticSearch实践》Elasticsearch支持结构化和非结构化数据检索,通过索引创建和倒排索引文档,提高搜索效率,它基于Lucene封装,分为索引库、类型... 目录一:ElasticSearch支持对结构化和非结构化的数据进行检索二:ES的核心概念Index:

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp