三金的代码库 2020-08-08 16:49 采纳率: 0%
浏览 112
已采纳

双指针的原理是啥--为什么一起走相遇了就是第一个节点

找两个链表的第一个公共节点

图片说明
这是我在leetcode上刷到的题,为什么相遇了就一定是第一个节点呢,有点想不通

/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     struct ListNode *next;
 * };
 */
struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) {
    int i,j=0,min,count=0,count1=0;
    struct ListNode *p;
    struct ListNode *q;
    p=headA;
    q=headB;
    if(p==NULL||q==NULL)
        return NULL;
    while(p!=q)
    {
        p=p?p->next:headB;
         q=q?q->next:headA;
    }
    return p;
}

  • 写回答

1条回答 默认 最新

  • threenewbee 2020-08-08 17:20
    关注

    不是第一个节点,而是第一个公共节点。因为从开头开始比较,遇到相同,显然就是第一个相同的节点

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已采纳回答 9月30日

悬赏问题

  • ¥15 Todesk 远程写代码 anaconda jupyter python3
  • ¥15 我的R语言提示去除连锁不平衡时clump_data报错,图片以下所示,卡了好几天了,苦恼不知道如何解决,有人帮我看看怎么解决吗?
  • ¥15 在获取boss直聘的聊天的时候只能获取到前40条聊天数据
  • ¥20 关于URL获取的参数,无法执行二选一查询
  • ¥15 液位控制,当液位超过高限时常开触点59闭合,直到液位低于低限时,断开
  • ¥15 marlin编译错误,如何解决?
  • ¥15 有偿四位数,节约算法和扫描算法
  • ¥15 VUE项目怎么运行,系统打不开
  • ¥50 pointpillars等目标检测算法怎么融合注意力机制
  • ¥20 Vs code Mac系统 PHP Debug调试环境配置