力扣206.反转链表C++

本文详细介绍了如何反转单链表,提供了具体的步骤解析和伪代码实现。通过设置3个虚拟节点pre、p和next,逐步调整节点指针方向,最终完成链表反转。需要注意在移动next节点时判断其是否为空,防止越界。此题还需处理链表为空的情况。

一.题目

  给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

 

提示:

  • 链表中节点的数目范围是 [0, 5000]
  • -5000 <= Node.val <= 5000

解析:设置3个虚拟节点pre为空,p点为头结点,next为头结点的下一个节点。将p节点的下一个节点指向pre,将pre移动到p的位置,p点移动到next位置,next再往后移动一个位置,以此类推,直到p点不存在(p==nullptr)。此时,pre在链表的最后位置,return pre->next即可。

注意:1.此题示例3,还应判空。

    2.next移动过程中,应加入前提if(next),因为next先为空,想访问成员变量没有空间。

实现过程如下:

 代码实现:

 

力扣平台上关于链表的内容丰富,涵盖题目、解题思路等方面。 ### 练习题及解题代码 有反转链表的练习题,对应的 Java 代码如下: ```java public class Num206_reverseList { public ListNode reverseList(ListNode head) { //当链表为空或者 只有一个是时候,就不需要翻转链表了 if(head == null || head.next == null){ return head; } ListNode dummyHead = new ListNode(); while(head != null){ ListNode node = new ListNode(head.val); node.next = dummyHead.next; dummyHead.next = node; head = head.next; } return dummyHead.next; } } ``` 还有迭代法实现反转链表的 Java 代码: ```java /** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode() {} * ListNode(int val) { this.val = val; } * ListNode(int val, ListNode next) { this.val = val; this.next = next; } * } */ class Solution { public ListNode reverseList(ListNode head) { ListNode prev = null; ListNode curr = head; while (curr != null) { ListNode next = curr.next; curr.next = prev; prev = curr; curr = next; } return prev; } } ``` 以及使用 C++ 实现反转链表的代码: ```cpp class Solution { public: ListNode* reverseList(ListNode* head) { ListNode* prev = nullptr; ListNode* curr = head; while (curr) { ListNode* next = curr->next; curr->next = prev; prev = curr; curr = next; } return prev; } }; ``` ### 解题思路 对于反转链表,一种思路是先判断链表是否为空或只有一个节点,若是则无需反转;若不是,则通过创建虚拟头节点,不断将原链表节点插入到虚拟头节点之后实现反转。另一种迭代法思路是使用两个指针 `prev` 和 `curr`,遍历链表,将当前节点的 `next` 指针指向前一个节点,不断更新 `prev` 和 `curr` 指针,最后返回 `prev` 指针指向的节点。对于重排链表,可将链表后半部分节点压入栈中,再进行相应操作 [^1][^3][^4]。 ### 特定问题处理思路 对于反转链表中指定区间 `(left, right)` 的情况,要先找到 `left` 的前一个节点 `pre` 和 `right` 节点,将该区间分离(`pre->next = nullptr`,`right->next = nullptr`),反转该区间链表后再连接起来 [^5]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值