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;
相关推荐
VT.馒头1 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
进击的小头2 小时前
实战案例:51单片机低功耗场景下的简易滤波实现
c语言·单片机·算法·51单片机
czy87874753 小时前
const 在 C/C++ 中的全面用法(C/C++ 差异+核心场景+实战示例)
c语言·开发语言·c++
pcm1235675 小时前
设计C/S架构的IM通信软件(4)
java·c语言·架构
代码无bug抓狂人5 小时前
C语言之表达式括号匹配
c语言·开发语言·算法
不穿格子的程序员6 小时前
从零开始写算法——普通数组篇:缺失的第一个正数
算法·leetcode·哈希算法
晓13137 小时前
第二章 【C语言篇:入门】 C 语言基础入门
c语言·算法
jiang_changsheng7 小时前
环境管理工具全景图与深度对比
java·c语言·开发语言·c++·python·r语言
VT.馒头8 小时前
【力扣】2722. 根据 ID 合并两个数组
javascript·算法·leetcode·职场和发展·typescript
执着2598 小时前
力扣hot100 - 108、将有序数组转换为二叉搜索树
算法·leetcode·职场和发展