• 相交链表


    题目描述:

    编写一个程序,找到两个单链表相交的起始节点。

    如下面的两个链表:

    输入:intersectVal = 8, listA = [4,1,8,4,5], listB = [5,0,1,8,4,5], skipA = 2, skipB = 3
    输出:Reference of the node with value = 8
    输入解释:相交节点的值为 8 (注意,如果两个链表相交则不能为 0)。从各自的表头开始算起,链表 A 为 [4,1,8,4,5],链表 B 为 [5,0,1,8,4,5]。在 A 中,相交节点前有 2 个节点;在 B 中,相交节点前有 3 个节点。

    代码
    //go
    
    func getIntersectionNode(headA, headB *ListNode) *ListNode {
     if headA == nil || headB == nil {
      return nil
     }
     /**
       定义两个指针, 第一轮让两个到达末尾的节点指向另一个链表的头部, 最后如果相遇则为交点(在第一轮移动中恰好抹除了长度差)
       两个指针等于移动了相同的距离, 有交点就返回, 无交点就是各走了两条指针的长度
       **/
     curA, curB := headA, headB
     // 在这里第一轮体现在pA和pB第一次到达尾部会移向另一链表的表头, 而第二轮体现在如果pA或pB相交就返回交点, 不相交最后就是null==null
     for curA != curB {
      if curA == nil {
       curA = headB
      } else {
       curA = curA.Next
      }
      if curB == nil {
       curB = headA
      } else {
       curB = curB.Next
      }
     }
     return curA
    }
    

      地址:https://mp.weixin.qq.com/s/iJwjQ5U_-8QUJoQ3DtJIgg

    small_lei_it 技术无止境,追求更高。
  • 相关阅读:
    http协议
    web及时通信传输的几种方法
    头像上传可预览实现代码
    JavaScript对象基础知识总结
    js异步流程的promise及generator
    数据整理
    前端技术分类整理
    HTML随笔
    前端内网穿透,localtunnel
    CSS记录
  • 原文地址:https://www.cnblogs.com/smallleiit/p/13644071.html
Copyright © 2020-2023  润新知