在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ Given a set of Each person may dislike some other people, and they should not go into the same group. Formally, if Return Example 1: Input: N = [[1,2],[1,3],[2,4]]
Output: true
Explanation: group1 [1,4], group2 [2,3]
Example 2: Input: N = [[1,2],[1,3],[2,3]]
Output: false
Example 3: Input: N = [[1,2],[2,3],[3,4],[4,5],[1,5]]
Output: false
Note:
给定一组 每个人都可能不喜欢其他人,那么他们不应该属于同一组。 形式上,如果 当可以用这种方法将每个人分进两组时,返回 示例 1: 输入:N = 4, dislikes = [[1,2],[1,3],[2,4]] 输出:true 解释:group1 [1,4], group2 [2,3] 示例 2: 输入:N = 3, dislikes = [[1,2],[1,3],[2,3]] 输出:false 示例 3: 输入:N = 5, dislikes = [[1,2],[2,3],[3,4],[4,5],[1,5]] 输出:false 提示:
【BFS】
Runtime: 836 ms
Memory Usage: 19.8 MB
1 class Solution { 2 func possibleBipartition(_ N: Int, _ dislikes: [[Int]]) -> Bool { 3 var len:Int = dislikes.count 4 if len < 2 {return true} 5 var color:[Int] = [Int](repeating:0,count:N + 1) 6 var graph:[[Int]] = [[Int]](repeating:[Int](),count:N + 1) 7 for i in 0..<len 8 { 9 var m:Int = dislikes[i][0] 10 var n:Int = dislikes[i][1] 11 graph[m].append(n) 12 graph[n].append(m) 13 } 14 for i in 1...N 15 { 16 if color[i] == 0 17 { 18 color[i] = 1 19 var q:[Int] = [Int]() 20 q.append(i) 21 while (!q.isEmpty) 22 { 23 var cur:Int = q.removeFirst() 24 for j in graph[cur] 25 { 26 if color[j] == 0 27 { 28 color[j] = color[cur] == 1 ? 2 : 1 29 q.append(j) 30 } 31 else 32 { 33 if color[j] == color[cur] {return false} 34 } 35 } 36 } 37 } 38 } 39 return true 40 } 41 } 【DFS】 Runtime: 1560 ms
Memory Usage: 50.2 MB
1 class Solution { 2 func possibleBipartition(_ N: Int, _ dislikes: [[Int]]) -> Bool { 3 var graph:[[Int]] = [[Int]](repeating:[Int](repeating:0,count:N),count:N) 4 for d in dislikes 5 { 6 graph[d[0] - 1][d[1] - 1] = 1 7 graph[d[1] - 1][d[0] - 1] = 1 8 } 9 var group:[Int] = [Int](repeating:0,count:N) 10 for i in 0..<N 11 { 12 if group[i] == 0 && !dfs(graph, &group, i, 1) 13 { 14 return false 15 } 16 } 17 return true 18 } 19 20 func dfs(_ graph:[[Int]],_ group:inout [Int],_ index:Int,_ g:Int) -> Bool 21 { 22 group[index] = g 23 for i in 0..<graph.count 24 { 25 if graph[index][i] == 1 26 { 27 if group[i] == g 28 { 29 return false 30 } 31 if group[i] == 0 && !dfs(graph, &group, i, -g) 32 { 33 return false 34 } 35 } 36 } 37 return true 38 } 39 }
|
请发表评论