LeetCode 1766. Tree of Coprimes

DFS

There is a tree (i.e., a connected, undirected graph that has no cycles) consisting of n nodes numbered from 0 to n - 1 and exactly n - 1 edges. Each node has a value associated with it, and the root of the tree is node 0.

To represent this tree, you are given an integer array nums and a 2D array edges. Each nums[i] represents the ith node's value, and each edges[j] = [uj, vj] represents an edge between nodes uj and vj in the tree.

Two values x and y are coprime if gcd(x, y) == 1 where gcd(x, y) is the greatest common divisor of x and y.

An ancestor of a node i is any other node on the shortest path from node i to the root. A node is not considered an ancestor of itself.

Return an array ans of size n, where ans[i] is the closest ancestor to node i such that nums[i] and nums[ans[i]] are coprime, or -1 if there is no such ancestor.

Example 1:

Example 2:

Constraints:

  • nums.length == n

  • 1 <= nums[i] <= 50

  • 1 <= n <= 105

  • edges.length == n - 1

  • edges[j].length == 2

  • 0 <= uj, vj < n

  • uj != vj

Solution:

English Version in Youtube

中文版解答Youtube Link

中文版解答Bilibili Link

Last updated

Was this helpful?