链表双指针总结(1)- LeetCode - 每日一题 - Day2

链表的两大劣势就是无法快速访问某个元素和涉及链表的长度问题,但是有这么几个题就是专门针对这方面出的,例如:

链表的中间结点

一、链表的中间结点:
①奇数个结点的情况:
思路:slow每次走一步,fast每次走两步,相当于fast走完的时候slow只走了fast的一半也就是全程的一半。(slow先走,否则到不了中点)
在这里插入图片描述在这里插入图片描述

②偶数个结点的情况
思路和奇数的一样,只不过返回的是第二个中间节点
在这里插入图片描述

struct ListNode* middleNode(struct ListNode* head)
{
    struct ListNode* slow = head, * fast = head;
    while (fast && fast->next)
    {
        slow = slow->next;
        fast = fast->next->next;
    }
    return slow;
}

需要注意的是while循环的条件必须是这个顺序,否则写成这样的话会错误

while (fast->next && fast)

错误点:
①在结点为奇数时:fast已经到了最后一个结点,slow也到了中间结点,但由于while表达式先判断的是fast->next不为空,所以会继续往下走导致slow过头。
在这里插入图片描述
②在结点为偶数时:
在这种情况如果已经找到了目标结点,但是需要再进行循环判断,先判断的是fast->next那么此时就会造成空指针访问,但是如果换成正确写法的话就会先判断fast是否为空,“与”符号若是前面的表达式为false那么直接退出不会执行下一个表达式,所以也就没有非法访问的问题。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

久菜

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值