leetcode 817. Linked List Components

leetcode 817. Linked List Components


原题地址:https://leetcode.com/problems/linked-list-components/

题目

We are given head, the head node of a linked list containing unique integer values.

We are also given the list G, a subset of the values in the linked list.

Return the number of connected components in G, where two values are connected if they appear consecutively in the linked list.

Example 1:
Input: 
head: 0->1->2->3
G = [0, 1, 3]
Output: 2
Explanation: 
0 and 1 are connected, so [0, 1] and [3] are the two connected components.
Example 2:
Input: 
head: 0->1->2->3->4
G = [0, 3, 1, 4]
Output: 2
Explanation: 
0 and 1 are connected, 3 and 4 are connected, so [0, 1] and [3, 4] are the two connected components.

Note:

  • If N is the length of the linked list given by head, 1 <= N <= 10000.
  • The value of each node in the linked list will be in the range [0, N - 1].
  • 1 <= G.length <= 10000.
  • G is a subset of all values in the linked list.

python代码

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

class Solution:
    def numComponents(self, head, G):
        """
        :type head: ListNode
        :type G: List[int]
        :rtype: int
        """
        if head == None:
            return 0
        h = ListNode(0)
        h.next = head
        li = []
        while h.next != None:
            li.append(h.next.val)
            h = h.next

        dic = {}
        for i in range(len(li)):
            dic[li[i]] = i

        G1 = [dic[i] for i in G]
        G1.sort()
        if len(G1) == 1:
            return 1
        else:
            num = 1
            for i in range(len(G1)-1):
                if G1[i+1]-G1[i] != 1:
                    num+=1
            return num

版权声明:转载注明 http://blog.csdn.net/birdreamer/article/details/79954042

阅读更多
个人分类: leetcode python
上一篇leetcode 816. Ambiguous Coordinates
下一篇leetcode 819. Most Common Word
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭