码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • leetcode(力扣):203移除链表元素 leetcode(力扣):206反转链表 leetcode(力扣):876.链表的中间结点多种解法


    目录

    203.移除链表元素

    解法一:将目标元素前一个元素存放地址改为下一元素地址

    解法二:遍历原链表,把不是val的节点拿出来进行尾插到新链表​编辑

    解法三:有哨兵位解法->头节点不存储有效数据​编辑

    206.反转链表

    方法一:创建新指针​编辑方法一:创建新指针进行反转​编辑

    方法二:将指针方向颠倒​编辑

    876. 链表的中间结点


    203.移除链表元素

    解法一:将目标元素前一个元素存放地址改为下一元素地址

    1. struct ListNode* removeElements(struct ListNode* head, int val)
    2. {
    3. struct ListNode* prev = NULL;
    4. struct ListNode* cur = head;
    5. if (head == NULL)//检验链表是否为空
    6. {
    7. return head;
    8. }
    9. while (cur)
    10. {
    11. if (cur->val == val)
    12. {
    13. if (cur == head)//if(prev==NULL)
    14. {
    15. //头删->以防该数组组成相同倒是prev一直为NULL导致error
    16. head = cur->next;
    17. free(cur);
    18. cur = head;
    19. }
    20. else
    21. {
    22. //删除
    23. prev->next = cur->next;//将cur上一个元素的指针存放的地址改为cur存放的地址即cur下一个元素的地址
    24. free(cur);//释放cur
    25. cur = prev->next;//使cur指向prev的下一个元素
    26. }
    27. }
    28. else
    29. {
    30. prev = cur;
    31. cur = cur->next;
    32. }
    33. }
    34. return head;
    35. }

    解法二:遍历原链表,把不是val的节点拿出来进行尾插到新链表

    1. struct ListNode* removeElements(struct ListNode* head, int val)
    2. {
    3. struct ListNode* cur = head;
    4. struct ListNode* tail = NULL;
    5. head = NULL;//防止野指针
    6. while (cur)
    7. {
    8. if (cur->val == val)
    9. {
    10. //删除
    11. struct ListNode* del = cur;
    12. cur = cur->next;
    13. free(del);
    14. }
    15. else
    16. {
    17. //尾插->第一步
    18. if (tail==NULL)
    19. {
    20. head = tail = cur;
    21. }
    22. else
    23. {
    24. tail->next = cur;
    25. tail = tail->next;
    26. }
    27. cur = cur->next;
    28. }
    29. }
    30. if(tail!=NULL)
    31. tail->next = NULL;//防止野指针
    32. return head;
    33. }

    解法三:有哨兵位解法->头节点不存储有效数据

    该解法好处在于无需考虑第一步尾插

    1. struct ListNode* removeElements(struct ListNode* head, int val)
    2. {
    3. struct ListNode* cur = head;
    4. struct ListNode* tail = NULL;
    5. //哨兵位的头节点
    6. head = tail = (struct ListNode*)malloc(sizeof(struct ListNode));
    7. tail->next = NULL;
    8. while (cur)
    9. {
    10. if (cur->val == val)
    11. {
    12. //删除
    13. struct ListNode* del = cur;
    14. cur = cur->next;
    15. free(del);
    16. }
    17. else
    18. {
    19. tail->next = cur;
    20. tail = tail->next;
    21. cur = cur->next;
    22. }
    23. }
    24. tail->next=NULL;
    25. //释放哨兵位
    26. struct ListNode* del = head;
    27. head = head->next;
    28. free(del);
    29. return head;
    30. }

    206.反转链表

    方法一:创建新指针方法一:创建新指针进行反转

    1. struct ListNode* reverseList(struct ListNode* head)
    2. {
    3. struct ListNode* newhead = NULL;
    4. struct ListNode* cur = head;
    5. while (cur)
    6. {
    7. //存放cur下一节点地址
    8. struct ListNode* next = cur->next;
    9. //头插
    10. cur->next = newhead;//将前一个节点地址存放在当前cur中
    11. newhead = cur;//nwehead后移
    12. cur = next;//原链表指针后移一位
    13. }
    14. return newhead;
    15. }

    方法二:将指针方向颠倒

    1. struct ListNode* reverseList(struct ListNode* head)
    2. {
    3. //防止链表为空
    4. if (head == NULL)
    5. {
    6. return NULL;
    7. }
    8. struct ListNode* n1, * n2, * n3;
    9. n1 = NULL;
    10. n2 = head;
    11. n3 = n2->next;
    12. while (n2)
    13. {
    14. //倒指向
    15. n2->next = n1;
    16. //迭代
    17. n1 = n2;
    18. n2 = n3;
    19. //防止n3越界访问
    20. if (n3)
    21. n3 = n3->next;
    22. }
    23. //最后一步时,n1=n2处于反转后首元素位置,故直接return n1
    24. return n1;
    25. }

    876. 链表的中间结点


    构建两个指针:快慢指针slow,fast
    slow一次走一步,fast一次走两步,当fast走到尾的时候slow就走到了中间。
    偶数有两个中间节点,题目要求返回第二个->fast==NULL; 是停止。

    1. struct ListNode* middleNode(struct ListNode* head)
    2. {
    3. struct ListNode* slow, * fast;
    4. slow = fast = head;
    5. //fast:检验奇数,fast->next:检验偶数
    6. while (fast && fast->next)
    7. {
    8. slow = slow->next;
    9. fast = fast->next->next;
    10. }
    11. return slow;
    12. }
  • 相关阅读:
    浅谈数字化工厂对于企业变革意义
    传奇服务端常用文件功能说明
    记一次 .NET 某医疗住院系统 崩溃分析
    建立密切业务合作关系,供应商SRM系统助力企业做好新材料供应商品质管控
    android studio cmake生成.a文件(静态库)及调用(c c++)静态库.a
    【字符串的copy Objective-C语言】
    用Java写一个贪吃蛇游戏
    Mqtt入门:在线调试连接阿里云
    centOS7中启动MySQL数据库提示: Failed to start mysqld.service Unit not found
    人力资源服务升级正当时,法大大助力佩信集团加速数字化
  • 原文地址:https://blog.csdn.net/2301_77649794/article/details/132735471
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号