目录
一、前言
反转链表这道题,可以说是--链表专题--,最经典的一道题,也是在面试中频率最高的一道题目,通常在面试中,面试官可能会要求我们写出多种解法来实现这道题目,所以大家需要对这道题目非常熟悉哦!!
本片博客就来详细的讲讲解一下 反转链表的多种实现方法,让我们的面试变的更加顺利!!!
二、题目描述
给你 单链表 的头节点
head,请你反转链表,并返回反转后的链表。

三、解题方法
⭐ 头插法 --- 创建新的链表
头插这种方法,就是将结点一一地插入到新链表的头前,所以我们需要先去建立出一个新的链表头,也就是我下面的这个【rhead】,通过去遍历原先的链表将这些结点一一转移过去即可
- 定义三个 变量 cur 、newnode 、rhead
- cur :用于遍历整个旧链表 newnode :用于记录cur的下一个节点,防止旧链表找不到
- rhead :新链表的头节点
// 重新创建一个链表,将之前的链表进行头插即可
struct ListNode* rphead = NULL;
// 进行指针变换
struct ListNode* cur = head;

- 开始头插,cur 节点的 next 指向 rhead 节点,然后更新 rhe

最低0.47元/天 解锁文章
1076

被折叠的 条评论
为什么被折叠?



