面试:阿里伯乐在线评测链表

Posted turboliu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了面试:阿里伯乐在线评测链表相关的知识,希望对你有一定的参考价值。

  如果两个链表相交,又都不存在环,那么从第一个相交点开始之后的结点都相同(构成了一个Y型)。因此,只要分别遍历这两个链表,找到末尾结点,如果末尾结点相同,即可确认相交。
  如果要求这种情况的交点,由于相交部分全部都相同,所以彼此的长度差异存在于相交之前的部分。因此,只需要先得到两个链表的差d,然后将较长的链表截去前d个结点;此时,两个链表同时出发向后遍历,第一个相等的结点即为交点。
技术分享图片
class ListNode:
    def __init__(self, x):
        self.val = x
        self.next = None
def node(l1, l2):
    length1, lenth2 = 0, 0
    # 求两个链表长度
    while l1.next:
        l1 = l1.next
        length1 += 1
    while l2.next:
        l2 = l2.next
        length2 += 1
    # 长的链表先走
    if length1 > lenth2:
        for _ in range(length1 - length2):
            l1 = l1.next
    else:
        for _ in range(length2 - length1):
            l2 = l2.next
    while l1 and l2:
        if l1.next == l2.next:
            return l1.next
        else:
            l1 = l1.next
            l2 = l2.next

 

 

 

以上是关于面试:阿里伯乐在线评测链表的主要内容,如果未能解决你的问题,请参考以下文章

[python篇] [伯乐在线][1]永远别写for循环

字节跳动+百度+阿里巴巴高频面试题之链表专题

字节跳动+百度+阿里巴巴高频面试题之链表专题

阿里面试题: 将两个升序链表合并成一个升序链表

Python爬虫-爬取伯乐在线美女邮箱

经验总结:Java高级工程师面试题-字节跳动,成功跳槽阿里!