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

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

image-20240710180427512

第一种思路🧐:

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

image-20240710180851338

代码🔎:

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上

image-20240710184622477

代码🔎:

struct ListNode* rhead = NULL;
    struct ListNode* cur = head;
    while(cur)
    {
        struct ListNode* tail = cur->next; //定义在里面则能防止访问到野指针
        cur->next = rhead; //头插
        rhead = cur; //更新头结点
        cur = tail; //回到原链表
    }
    return rhead;

image-20240710185040582

相关推荐

  1. 【leetcode】题目总结

    2024-07-11 19:28:04       30 阅读
  2. 【力扣 206】 C++题解+头插法)

    2024-07-11 19:28:04       52 阅读
  3. C语言)

    2024-07-11 19:28:04       40 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-11 19:28:04       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-11 19:28:04       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-11 19:28:04       58 阅读
  4. Python语言-面向对象

    2024-07-11 19:28:04       69 阅读

热门阅读

  1. FastAPI -- 第一弹

    2024-07-11 19:28:04       21 阅读
  2. vue2 实现原生 WebSocket

    2024-07-11 19:28:04       20 阅读
  3. 第五十章 Web Service URL 汇总

    2024-07-11 19:28:04       22 阅读
  4. MyEclipse不能自动编译解决方案

    2024-07-11 19:28:04       22 阅读
  5. Node.js path模块

    2024-07-11 19:28:04       19 阅读
  6. Node.js Stream

    2024-07-11 19:28:04       22 阅读
  7. 前端时间格式传入后端负载里面没有东西

    2024-07-11 19:28:04       23 阅读
  8. Spring如何控制Bean加载+执行顺序

    2024-07-11 19:28:04       22 阅读
  9. futures.toArray(new CompletableFuture[0])

    2024-07-11 19:28:04       22 阅读
  10. 远程Linux机器图形化界面使用及音频转发

    2024-07-11 19:28:04       25 阅读