LeetCode LCR024.反转链表 经典题目 C写法

LeetCode LCR024.反转链表 经典题目C写法

第一种思路🧐:

​ 使用三个指针,n1,n2,n3,n1为空,n2为头结点,n3为头结点的next。开始反转后,n1赋值给n2的next,n2赋值给n1,n3赋值给n2找到下一个反转的结点,n3找它的next遍历。如此迭代就完成了反转

代码🔎:

c 复制代码
struct ListNode* reverseList(struct ListNode* head){
    if(head == NULL) //链表为空直接返回
        return head;
    struct ListNode* n1 = NULL;
    struct ListNode* n2 = head;
    struct ListNode* n3 = n2->next;
    while(n2)
    {
        n2->next = n1; //反转该结点的指向
        n1 = n2; //变成下一个结点,方便n2反转
        n2 = n3; //n2找到下一个要反转的结点
        if(n3) //当n3已经为空时就停止,不然就访问到野指针了
            n3 = n3->next; //n3找到后一个结点
    }
    return n1;
}

第二种思路🧐:

​ 创建两个指针rhead和cur,rhead作为新的头,cur进行链表遍历,将每个结点头插在rhead上

代码🔎:

c 复制代码
struct ListNode* rhead = NULL;
    struct ListNode* cur = head;
    while(cur)
    {
        struct ListNode* tail = cur->next; //定义在里面则能防止访问到野指针
        cur->next = rhead; //头插
        rhead = cur; //更新头结点
        cur = tail; //回到原链表
    }
    return rhead;
相关推荐
永远都不秃头的程序员(互关)12 分钟前
C语言 基本语法
c语言·开发语言
赖small强1 小时前
【Linux C/C++开发】Linux 平台 Stack Protector 机制深度解析
linux·c语言·c++·stack protector·stack-protector·金丝雀机制
CoderYanger1 小时前
动态规划算法-子序列问题(数组中不连续的一段):28.摆动序列
java·算法·leetcode·动态规划·1024程序员节
有时间要学习2 小时前
面试150——第二周
数据结构·算法·leetcode
liu****2 小时前
3.链表讲解
c语言·开发语言·数据结构·算法·链表
赖small强3 小时前
【Linux C/C++开发】Linux C/C++ 堆栈溢出:原理、利用与防护深度指南
linux·c语言·c++·stack·堆栈溢出
赖small强4 小时前
【Linux C/C++开发】Linux C/C++ 高效延迟崩溃分析:基于 mprotect 的内存陷阱技术 (Electric Fence)
linux·c语言·c++·mprotect·buffer overflow
繁华似锦respect4 小时前
C++ & Linux 中 GDB 调试与内存泄漏检测详解
linux·c语言·开发语言·c++·windows·算法
小白程序员成长日记5 小时前
2025.12.03 力扣每日一题
算法·leetcode·职场和发展
元亓亓亓5 小时前
LeetCode热题100--20. 有效的括号--简单
linux·算法·leetcode