剑指 Offer 24. 反转链表【链表】
admin
2024-01-25 05:44:06
0

难度等级:简单

 上一篇算法:

剑指 Offer 06. 从尾到头打印链表【链表】

力扣此题地址:

剑指 Offer 24. 反转链表 - 力扣(LeetCode)

1.题目:反转链表

定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。

2.解题思路:

两种方式:1.定义反转头来实现    2.递归方式实现(比较难懂)

1.定义反转头实现:

思路:先创建一个反转头结点,然后将正序链表中的结点从前到后依次放入反转链表中,
//     同时,每次将结点放入反转链表都是插入到第一个结点,与反转头节点直接相连,
//     这里用循环逐个插入,最后将现有的头结点指向反转后的第一个结点即可。

2.递归方式实现(比较难懂)

思路:递归反转就是从原链表的第一个存储节点开始,依次递归调用反转每一个结点,
//     直到把最后一个反转完毕,真个链表就反转完毕了。

3.代码实现:

1.反转头实现:

/*** Definition for singly-linked list.* public class ListNode {*     int val;*     ListNode next;*     ListNode(int x) { val = x; }* }*/
class Solution {public ListNode reverseList(ListNode head) {ListNode pre = null;ListNode cur = head;ListNode next = null;while(cur != null) {next = cur.next;cur.next = pre;pre = cur;cur = next;}return pre;}
}

2.递归方式:

/*** Definition for singly-linked list.* public class ListNode {*     int val;*     ListNode next;*     ListNode(int x) { val = x; }* }*/
class Solution {public ListNode reverseList(ListNode head) {// 寻找递归终止条件// 1、head 指向的结点为 null // 2、head 指向的结点的下一个结点为 null // 在这两种情况下,反转之后的结果还是它自己本身if( head == null || head.next == null)  return head;// 不断的通过递归调用,直到无法递归下去,递归的最小粒度是在最后一个节点// 因为到最后一个节点的时候,由于当前节点 head 的 next 节点是空,所以会直接返回 headListNode cur = reverseList(head.next);// 比如原链表为 1 --> 2 --> 3 --> 4 --> 5// 第一次执行下面代码的时候,head 为 4,那么 head.next = 5// 那么 head.next.next 就是 5.next ,意思就是去设置 5 的下一个节点// 等号右侧为 head,意思就是设置 5 的下一个节点是 4// 这里出现了两个 next// 第一个 next 是「获取」 head 的下一节点// 第二个 next 是「设置」 当前节点的下一节点为等号右侧的值head.next.next = head;// head 原来的下一节点指向自己,所以 head 自己本身就不能再指向原来的下一节点了// 否则会发生无限循环head.next = null;// 我们把每次反转后的结果传递给上一层return cur;}
}

参考单链表里的反转链表(1.用反转头实现 2.用递归实现):

单链表的基本操作

相关内容

热门资讯

自己制作安卓系统教程,自制安卓... 亲爱的读者们,你是否曾梦想过摆脱安卓系统的束缚,亲手打造一个只属于你自己的操作系统?别再羡慕那些技术...
安卓系统调整器下载,轻松优化手... 你有没有发现,手机用久了,系统总是有点小问题,比如卡顿啦,电池续航不给力啦,这些小烦恼是不是让你头疼...
怎样升级安卓系统视频,安卓系统... 亲爱的手机控们,你是否也和我一样,对手机系统升级充满了好奇和期待?想象你的安卓手机在经过一番“变身”...
鸿蒙系统和安卓系统哪个广告少,... 你有没有发现,现在手机市场上的操作系统真是五花八门,让人挑花了眼。不过,最近有个话题特别火,那就是鸿...
安卓系统openrec怎么注册... 你有没有想过,想要在安卓系统上体验一把OpenRec的乐趣,却发现注册步骤有点让人摸不着头脑?别急,...
怎样更新车机安卓系统,车机安卓... 亲爱的车主朋友们,你是不是也和我一样,对车机系统里的安卓系统充满了好奇?想要让它焕然一新,变得更加强...
安卓机换系统后照片,照片如何完... 你有没有遇到过这种情况:手机里的照片突然消失得无影无踪,心里那个急啊,就像热锅上的蚂蚁。别担心,今天...
安卓手机定位系统软件,技术原理... 你有没有想过,你的安卓手机里那些神奇的定位系统软件是怎么工作的呢?它们就像你的私人侦探,随时随地告诉...
安卓制作win系统盘,打造Wi... 亲爱的读者,你是否曾想过,将安卓系统的魅力与Windows系统的强大功能完美结合?今天,就让我带你一...
系统警告_您的安卓手机,揭秘潜... 亲爱的手机主人,最近你的安卓手机是不是突然跳出来一个系统警告,让你心头一紧?别慌,今天就来给你详细解...
投屏安卓系统版本,揭秘不同版本... 你有没有想过,家里的电视屏幕那么大,却只能用它来看电视?现在,有了安卓系统,你就可以把手机上的精彩内...
安卓官方系统升级软件,畅享智能... 你有没有发现,你的安卓手机最近是不是变得有点儿“年轻”了?没错,这就是安卓官方系统升级的魅力所在!今...
安卓系统铃声长度是多少,时长差... 你有没有想过,为什么你的手机每次收到消息时,都会响起那熟悉的铃声?是不是好奇过,安卓系统的铃声长度到...
酷派电脑系统安卓,深度解析与全... 亲爱的读者们,你是否曾对那些在电脑世界里游刃有余的酷派电脑系统安卓版心生好奇?今天,就让我带你一起揭...
什么系统可以装安卓软件,基于A... 你有没有想过,你的手机里那些好玩又实用的安卓软件,其实也可以在其他设备上运行呢?没错,这就是今天我们...
制作安卓系统主题软件,安卓系统... 你有没有想过,给你的安卓手机换一个全新的面貌?没错,就是那种一打开手机,就能感受到完全不同的风格和氛...
安卓系统平板怎么截屏,操作指南... 亲爱的平板用户,你是不是也和我一样,有时候想记录下平板上的精彩瞬间,却发现截屏功能有点神秘?别担心,...
安卓系统不推送更新,揭秘背后的... 最近是不是发现你的安卓手机有点儿“懒”啊?更新推送总是慢吞吞的,让人等得花儿都谢了。别急,今天就来给...
ape格式转换安卓系统,享受音... 你有没有想过,你的安卓手机里的ape格式音乐文件,竟然可以通过一个小小的转换,焕发出全新的生命力?没...
获取安卓系统加载器,核心功能与... 你有没有想过,你的安卓手机里那些神奇的软件和游戏是怎么被安装到你的设备上的呢?没错,就是通过一个叫做...