力扣HOT100之链表:206. 反转链表

这道题今天已经是第三次刷了,思路都知道但是代码就是写不对,我真的要红温了🤯🤯

以后这道题就统一用双指针法来做吧。

双指针,顾名思义,就是用两个指针来保存一些必要的变量,对于一段链表,我们要将其反转,我们必须知道这段链表的前置节点,当前遍历到的节点和当前节点的下一节点,我们分别用precurrenttemp来表示,如图所示

从上面到下面经历了一次反转,可以看到,在一次反转中,我们仅将current指向了原本的前置节点pre,然后将precurrenttemp的位置整体后移一位,然后周而复始,我们通过一个while循环来实现这样的处理流程,直到head == nullptr退出循环,此时pre指向原链表的最后一个元素,此时pre节点也是反转后的链表的首元素,因此我们直接返回pre指针即可。

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        //双指针法
        ListNode* pre = nullptr;  
        ListNode* temp;
        while(head){
            temp = head -> next;  //先保存head的下一个节点
            head -> next = pre;   //将head指向原链表的前置节点
            pre = head;
            head = temp;
        }
        return pre;
    }
};
相关推荐
@forever@20 小时前
【JAVA】LinkedList与链表
java·python·链表
吃着火锅x唱着歌21 小时前
LeetCode 1128.等价多米诺骨牌对的数量
算法·leetcode·职场和发展
十八岁讨厌编程21 小时前
【算法训练营 · 补充】LeetCode Hot100(中)
算法·leetcode
橘颂TA21 小时前
【剑斩OFFER】算法的暴力美学——最小覆盖字串
算法·c/c++·就业
wearegogog12321 小时前
基于混合蛙跳算法和漏桶算法的无线传感器网络拥塞控制与分簇新方法
网络·算法
Tiandaren1 天前
大模型应用03 || 函数调用 Function Calling || 概念、思想、流程
人工智能·算法·microsoft·数据分析
2301_795167201 天前
玩转Rust高级应用 如何进行理解Refutability(可反驳性): 模式是否会匹配失效
开发语言·算法·rust
小当家.1051 天前
[LeetCode]Hot100系列.贪心总结+思想总结
算法·leetcode·职场和发展
墨雪不会编程1 天前
数据结构—排序算法篇二
数据结构·算法·排序算法
ShineWinsu1 天前
对于数据结构:堆的超详细保姆级解析—上
数据结构·c++·算法·计算机·二叉树·顺序表·