环形链表2

 

 双指针:

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution:
    def detectCycle(self, head: ListNode) -> ListNode:
        if head is None or head.next is None:
            return 
        slow = fast = head
        while slow and fast and fast.next :
            slow = slow.next
            fast = fast.next.next
            if slow is fast:
                break
        if fast is None or fast.next is None: #表明没有环
            return 
        tmp = head
        while tmp is not slow:
            tmp = tmp.next
            slow = slow.next
        return slow
 
语言特性:
# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution:
    def detectCycle(self, head: ListNode) -> ListNode:
#        if head is None and head.next is None:
 #           return head 
        hashmap = []
        while head:
            if head in hashmap:
                return head
            hashmap.append(head)
            head = head.next
        return None
posted @ 2021-09-17 22:29  狼太白  阅读(23)  评论(0编辑  收藏  举报