From 375f3e312e17702d90fa50ed9be3a4e6fd7c1c25 Mon Sep 17 00:00:00 2001 From: Jason Sun <117045786+CryoJS@users.noreply.github.com> Date: Sat, 9 Nov 2024 21:07:02 -0500 Subject: [PATCH 01/14] Update content/3_Silver/Graph_Traversal.mdx --- content/3_Silver/Graph_Traversal.mdx | 101 +++++++++++++++++---------- 1 file changed, 65 insertions(+), 36 deletions(-) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index adc926ed5e..5ad8b09f61 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1082,6 +1082,44 @@ public class BuildingTeams { ``` + + +Note that the below solution passes in CPython3 but exceeds the time limit on test case #7 in PyPy3. + +```py +import sys +input = sys.stdin.readline + +sys.setrecursionlimit(int(1e5 + 1)) + +n, m = map(int, input().strip().split()) +adj = [[] for _ in range(n)] +team = [0] * n # 0 -> has not been assigned a team yet + +for _ in range(m): + a, b = map(int, map(int, input().strip().split())) + adj[a - 1].append(b - 1) + adj[b - 1].append(a - 1) + +def dfs(node): + for next_node in adj[node]: + if team[next_node]: + if team[next_node] == team[node]: + print("IMPOSSIBLE") + raise SystemExit + else: + team[next_node] = 2 if team[node] == 1 else 1 + dfs(next_node) + +for node in range(n): + if not team[node]: + team[node] = 1 + dfs(node) + +print(*team) +``` + + ### BFS Solution @@ -1210,46 +1248,37 @@ public class BuildingTeams { ```py +import sys from collections import deque +input = sys.stdin.readline -n, m = map(int, input().split()) - +n, m = map(int, input().strip().split()) adj = [[] for _ in range(n)] -for _ in range(m): - a, b = map(int, input().split()) - adj[a - 1].append(b - 1) - adj[b - 1].append(a - 1) - -assigned = [0 for _ in range(n)] -valid = True -for i in range(n): - if assigned[i] != 0: - continue - - assigned[i] = 1 - todo = deque([i]) - while todo: - curr = todo.popleft() - n_color = 2 if assigned[curr] == 1 else 1 - for next_ in adj[curr]: - if assigned[next_] != 0: - if assigned[next_] != n_color: - valid = False - break - else: - assigned[next_] = n_color - todo.append(next_) - - if not valid: - break +team = [0] * n # 0 -> has not been assigned a team yet - if not valid: - break - -if valid: - print(" ".join(str(i) for i in assigned)) -else: - print("IMPOSSIBLE") +for _ in range(m): + a, b = map(int, map(int, input().strip().split())) + adj[a - 1].append(b - 1) + adj[b - 1].append(a - 1) + +for node in range(n): + if not team[node]: + team[node] = 1 + queue = deque([node]) + + while queue: + node = queue.popleft() + + for next_node in adj[node]: + if team[next_node]: + if team[next_node] == team[node]: + print("IMPOSSIBLE") + raise SystemExit + else: + team[next_node] = 2 if team[node] == 1 else 1 + queue.append(next_node) + +print(*team) ``` From 37455a882138f715dd1c1eb4ba8c1cce4add986e Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Sun, 10 Nov 2024 02:15:58 +0000 Subject: [PATCH 02/14] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- content/3_Silver/Graph_Traversal.mdx | 72 +++++++++++++++------------- 1 file changed, 38 insertions(+), 34 deletions(-) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index 5ad8b09f61..f3d11faaaf 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1088,33 +1088,36 @@ Note that the below solution passes in CPython3 but exceeds the time limit on te ```py import sys + input = sys.stdin.readline sys.setrecursionlimit(int(1e5 + 1)) n, m = map(int, input().strip().split()) adj = [[] for _ in range(n)] -team = [0] * n # 0 -> has not been assigned a team yet +team = [0] * n # 0 -> has not been assigned a team yet for _ in range(m): - a, b = map(int, map(int, input().strip().split())) - adj[a - 1].append(b - 1) - adj[b - 1].append(a - 1) + a, b = map(int, map(int, input().strip().split())) + adj[a - 1].append(b - 1) + adj[b - 1].append(a - 1) + def dfs(node): - for next_node in adj[node]: - if team[next_node]: - if team[next_node] == team[node]: - print("IMPOSSIBLE") - raise SystemExit - else: - team[next_node] = 2 if team[node] == 1 else 1 - dfs(next_node) + for next_node in adj[node]: + if team[next_node]: + if team[next_node] == team[node]: + print("IMPOSSIBLE") + raise SystemExit + else: + team[next_node] = 2 if team[node] == 1 else 1 + dfs(next_node) + for node in range(n): - if not team[node]: - team[node] = 1 - dfs(node) + if not team[node]: + team[node] = 1 + dfs(node) print(*team) ``` @@ -1250,33 +1253,34 @@ public class BuildingTeams { ```py import sys from collections import deque + input = sys.stdin.readline n, m = map(int, input().strip().split()) adj = [[] for _ in range(n)] -team = [0] * n # 0 -> has not been assigned a team yet +team = [0] * n # 0 -> has not been assigned a team yet for _ in range(m): - a, b = map(int, map(int, input().strip().split())) - adj[a - 1].append(b - 1) - adj[b - 1].append(a - 1) + a, b = map(int, map(int, input().strip().split())) + adj[a - 1].append(b - 1) + adj[b - 1].append(a - 1) for node in range(n): - if not team[node]: - team[node] = 1 - queue = deque([node]) - - while queue: - node = queue.popleft() - - for next_node in adj[node]: - if team[next_node]: - if team[next_node] == team[node]: - print("IMPOSSIBLE") - raise SystemExit - else: - team[next_node] = 2 if team[node] == 1 else 1 - queue.append(next_node) + if not team[node]: + team[node] = 1 + queue = deque([node]) + + while queue: + node = queue.popleft() + + for next_node in adj[node]: + if team[next_node]: + if team[next_node] == team[node]: + print("IMPOSSIBLE") + raise SystemExit + else: + team[next_node] = 2 if team[node] == 1 else 1 + queue.append(next_node) print(*team) ``` From c3b0443ca02bc58feb95359e87d5921b15b306f8 Mon Sep 17 00:00:00 2001 From: Jason Sun <117045786+CryoJS@users.noreply.github.com> Date: Sat, 9 Nov 2024 23:38:14 -0500 Subject: [PATCH 03/14] Update content/3_Silver/Graph_Traversal.mdx --- content/3_Silver/Graph_Traversal.mdx | 76 ++++++++++++++-------------- 1 file changed, 37 insertions(+), 39 deletions(-) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index f3d11faaaf..0a31dd4825 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1084,40 +1084,39 @@ public class BuildingTeams { -Note that the below solution passes in CPython3 but exceeds the time limit on test case #7 in PyPy3. + +You have to submit with CPython (not PyPy3) to avoid exceeding the time limit. + ```py import sys - input = sys.stdin.readline sys.setrecursionlimit(int(1e5 + 1)) n, m = map(int, input().strip().split()) adj = [[] for _ in range(n)] -team = [0] * n # 0 -> has not been assigned a team yet +team = [0] * n # 0 -> has not been assigned a team yet for _ in range(m): - a, b = map(int, map(int, input().strip().split())) - adj[a - 1].append(b - 1) - adj[b - 1].append(a - 1) - + a, b = map(int, map(int, input().strip().split())) + adj[a - 1].append(b - 1) + adj[b - 1].append(a - 1) def dfs(node): - for next_node in adj[node]: - if team[next_node]: - if team[next_node] == team[node]: - print("IMPOSSIBLE") - raise SystemExit - else: - team[next_node] = 2 if team[node] == 1 else 1 - dfs(next_node) - + for next_node in adj[node]: + if team[next_node]: + if team[next_node] == team[node]: + print("IMPOSSIBLE") + raise SystemExit + else: + team[next_node] = 2 if team[node] == 1 else 1 + dfs(next_node) for node in range(n): - if not team[node]: - team[node] = 1 - dfs(node) + if not team[node]: + team[node] = 1 + dfs(node) print(*team) ``` @@ -1253,34 +1252,33 @@ public class BuildingTeams { ```py import sys from collections import deque - input = sys.stdin.readline n, m = map(int, input().strip().split()) adj = [[] for _ in range(n)] -team = [0] * n # 0 -> has not been assigned a team yet +team = [0] * n # 0 -> has not been assigned a team yet for _ in range(m): - a, b = map(int, map(int, input().strip().split())) - adj[a - 1].append(b - 1) - adj[b - 1].append(a - 1) + a, b = map(int, map(int, input().strip().split())) + adj[a - 1].append(b - 1) + adj[b - 1].append(a - 1) for node in range(n): - if not team[node]: - team[node] = 1 - queue = deque([node]) - - while queue: - node = queue.popleft() - - for next_node in adj[node]: - if team[next_node]: - if team[next_node] == team[node]: - print("IMPOSSIBLE") - raise SystemExit - else: - team[next_node] = 2 if team[node] == 1 else 1 - queue.append(next_node) + if not team[node]: + team[node] = 1 + queue = deque([node]) + + while queue: + node = queue.popleft() + + for next_node in adj[node]: + if team[next_node]: + if team[next_node] == team[node]: + print("IMPOSSIBLE") + raise SystemExit + else: + team[next_node] = 2 if team[node] == 1 else 1 + queue.append(next_node) print(*team) ``` From 4782a68bb0e59d4d2b501196374320f323d0a5f8 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Sun, 10 Nov 2024 04:39:23 +0000 Subject: [PATCH 04/14] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- content/3_Silver/Graph_Traversal.mdx | 72 +++++++++++++++------------- 1 file changed, 38 insertions(+), 34 deletions(-) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index 0a31dd4825..d123b351bd 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1090,33 +1090,36 @@ You have to submit with CPython (not PyPy3) to avoid exceeding the time limit. ```py import sys + input = sys.stdin.readline sys.setrecursionlimit(int(1e5 + 1)) n, m = map(int, input().strip().split()) adj = [[] for _ in range(n)] -team = [0] * n # 0 -> has not been assigned a team yet +team = [0] * n # 0 -> has not been assigned a team yet for _ in range(m): - a, b = map(int, map(int, input().strip().split())) - adj[a - 1].append(b - 1) - adj[b - 1].append(a - 1) + a, b = map(int, map(int, input().strip().split())) + adj[a - 1].append(b - 1) + adj[b - 1].append(a - 1) + def dfs(node): - for next_node in adj[node]: - if team[next_node]: - if team[next_node] == team[node]: - print("IMPOSSIBLE") - raise SystemExit - else: - team[next_node] = 2 if team[node] == 1 else 1 - dfs(next_node) + for next_node in adj[node]: + if team[next_node]: + if team[next_node] == team[node]: + print("IMPOSSIBLE") + raise SystemExit + else: + team[next_node] = 2 if team[node] == 1 else 1 + dfs(next_node) + for node in range(n): - if not team[node]: - team[node] = 1 - dfs(node) + if not team[node]: + team[node] = 1 + dfs(node) print(*team) ``` @@ -1252,33 +1255,34 @@ public class BuildingTeams { ```py import sys from collections import deque + input = sys.stdin.readline n, m = map(int, input().strip().split()) adj = [[] for _ in range(n)] -team = [0] * n # 0 -> has not been assigned a team yet +team = [0] * n # 0 -> has not been assigned a team yet for _ in range(m): - a, b = map(int, map(int, input().strip().split())) - adj[a - 1].append(b - 1) - adj[b - 1].append(a - 1) + a, b = map(int, map(int, input().strip().split())) + adj[a - 1].append(b - 1) + adj[b - 1].append(a - 1) for node in range(n): - if not team[node]: - team[node] = 1 - queue = deque([node]) - - while queue: - node = queue.popleft() - - for next_node in adj[node]: - if team[next_node]: - if team[next_node] == team[node]: - print("IMPOSSIBLE") - raise SystemExit - else: - team[next_node] = 2 if team[node] == 1 else 1 - queue.append(next_node) + if not team[node]: + team[node] = 1 + queue = deque([node]) + + while queue: + node = queue.popleft() + + for next_node in adj[node]: + if team[next_node]: + if team[next_node] == team[node]: + print("IMPOSSIBLE") + raise SystemExit + else: + team[next_node] = 2 if team[node] == 1 else 1 + queue.append(next_node) print(*team) ``` From a53d5446c4135c44fbfbf41912469f5a1d3bd1ce Mon Sep 17 00:00:00 2001 From: Jason Sun <117045786+CryoJS@users.noreply.github.com> Date: Sun, 10 Nov 2024 21:27:52 -0500 Subject: [PATCH 05/14] Update content/3_Silver/Graph_Traversal.mdx --- content/3_Silver/Graph_Traversal.mdx | 48 +++++++++++++--------------- 1 file changed, 22 insertions(+), 26 deletions(-) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index d123b351bd..9d3eed4b66 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1090,37 +1090,34 @@ You have to submit with CPython (not PyPy3) to avoid exceeding the time limit. ```py import sys - input = sys.stdin.readline -sys.setrecursionlimit(int(1e5 + 1)) - n, m = map(int, input().strip().split()) -adj = [[] for _ in range(n)] -team = [0] * n # 0 -> has not been assigned a team yet +sys.setrecursionlimit(n + 3) # preventing recursion limit exceeded error +adj = [[] for _ in range(n)] +team = [0] * n # 0: not assigned yet, 1: team 1, 2: team 2 + for _ in range(m): - a, b = map(int, map(int, input().strip().split())) - adj[a - 1].append(b - 1) - adj[b - 1].append(a - 1) - - -def dfs(node): - for next_node in adj[node]: - if team[next_node]: - if team[next_node] == team[node]: - print("IMPOSSIBLE") - raise SystemExit - else: - team[next_node] = 2 if team[node] == 1 else 1 - dfs(next_node) - - + a, b = map(int, map(int, input().strip().split())) + adj[a - 1].append(b - 1) + adj[b - 1].append(a - 1) + +def dfs(node: int): + for next_node in adj[node]: + if team[next_node]: + if team[next_node] == team[node]: + print("IMPOSSIBLE") + raise SystemExit + else: + team[next_node] = 2 if team[node] == 1 else 1 + dfs(next_node) + for node in range(n): - if not team[node]: - team[node] = 1 - dfs(node) - + if not team[node]: + team[node] = 1 + dfs(node) + print(*team) ``` @@ -1255,7 +1252,6 @@ public class BuildingTeams { ```py import sys from collections import deque - input = sys.stdin.readline n, m = map(int, input().strip().split()) From 2d1ebab6a85b1c134a2abd23e4cfb29026d47db7 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Mon, 11 Nov 2024 02:29:13 +0000 Subject: [PATCH 06/14] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- content/3_Silver/Graph_Traversal.mdx | 44 +++++++++++++++------------- 1 file changed, 24 insertions(+), 20 deletions(-) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index 9d3eed4b66..08ef9ed2ab 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1090,34 +1090,37 @@ You have to submit with CPython (not PyPy3) to avoid exceeding the time limit. ```py import sys + input = sys.stdin.readline n, m = map(int, input().strip().split()) -sys.setrecursionlimit(n + 3) # preventing recursion limit exceeded error +sys.setrecursionlimit(n + 3) # preventing recursion limit exceeded error adj = [[] for _ in range(n)] -team = [0] * n # 0: not assigned yet, 1: team 1, 2: team 2 - +team = [0] * n # 0: not assigned yet, 1: team 1, 2: team 2 + for _ in range(m): - a, b = map(int, map(int, input().strip().split())) - adj[a - 1].append(b - 1) - adj[b - 1].append(a - 1) - + a, b = map(int, map(int, input().strip().split())) + adj[a - 1].append(b - 1) + adj[b - 1].append(a - 1) + + def dfs(node: int): - for next_node in adj[node]: - if team[next_node]: - if team[next_node] == team[node]: - print("IMPOSSIBLE") - raise SystemExit - else: - team[next_node] = 2 if team[node] == 1 else 1 - dfs(next_node) - + for next_node in adj[node]: + if team[next_node]: + if team[next_node] == team[node]: + print("IMPOSSIBLE") + raise SystemExit + else: + team[next_node] = 2 if team[node] == 1 else 1 + dfs(next_node) + + for node in range(n): - if not team[node]: - team[node] = 1 - dfs(node) - + if not team[node]: + team[node] = 1 + dfs(node) + print(*team) ``` @@ -1252,6 +1255,7 @@ public class BuildingTeams { ```py import sys from collections import deque + input = sys.stdin.readline n, m = map(int, input().strip().split()) From ca77264291c8c169b3c0160e987e144f79855e71 Mon Sep 17 00:00:00 2001 From: Jason Sun <117045786+CryoJS@users.noreply.github.com> Date: Mon, 11 Nov 2024 08:24:24 -0500 Subject: [PATCH 07/14] Update content/3_Silver/Graph_Traversal.mdx --- content/3_Silver/Graph_Traversal.mdx | 44 +++++++++++++--------------- 1 file changed, 20 insertions(+), 24 deletions(-) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index 08ef9ed2ab..076e7a60bf 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1090,37 +1090,34 @@ You have to submit with CPython (not PyPy3) to avoid exceeding the time limit. ```py import sys - input = sys.stdin.readline -n, m = map(int, input().strip().split()) -sys.setrecursionlimit(n + 3) # preventing recursion limit exceeded error +sys.setrecursionlimit(int(1e9)) # disable recursion limit +n, m = map(int, input().strip().split()) adj = [[] for _ in range(n)] team = [0] * n # 0: not assigned yet, 1: team 1, 2: team 2 - + for _ in range(m): - a, b = map(int, map(int, input().strip().split())) - adj[a - 1].append(b - 1) - adj[b - 1].append(a - 1) - - + a, b = map(int, map(int, input().strip().split())) + adj[a - 1].append(b - 1) + adj[b - 1].append(a - 1) + def dfs(node: int): - for next_node in adj[node]: - if team[next_node]: - if team[next_node] == team[node]: - print("IMPOSSIBLE") - raise SystemExit - else: - team[next_node] = 2 if team[node] == 1 else 1 - dfs(next_node) - - + for next_node in adj[node]: + if team[next_node]: + if team[next_node] == team[node]: + print("IMPOSSIBLE") + raise SystemExit + else: + team[next_node] = 2 if team[node] == 1 else 1 + dfs(next_node) + for node in range(n): - if not team[node]: - team[node] = 1 - dfs(node) - + if not team[node]: + team[node] = 1 + dfs(node) + print(*team) ``` @@ -1255,7 +1252,6 @@ public class BuildingTeams { ```py import sys from collections import deque - input = sys.stdin.readline n, m = map(int, input().strip().split()) From 02b9f5e512a5732db9cfd531ec7b264e124d4de0 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Mon, 11 Nov 2024 13:25:48 +0000 Subject: [PATCH 08/14] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- content/3_Silver/Graph_Traversal.mdx | 40 +++++++++++++++------------- 1 file changed, 22 insertions(+), 18 deletions(-) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index 076e7a60bf..64b58b300c 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1090,6 +1090,7 @@ You have to submit with CPython (not PyPy3) to avoid exceeding the time limit. ```py import sys + input = sys.stdin.readline sys.setrecursionlimit(int(1e9)) # disable recursion limit @@ -1097,27 +1098,29 @@ sys.setrecursionlimit(int(1e9)) # disable recursion limit n, m = map(int, input().strip().split()) adj = [[] for _ in range(n)] team = [0] * n # 0: not assigned yet, 1: team 1, 2: team 2 - + for _ in range(m): - a, b = map(int, map(int, input().strip().split())) - adj[a - 1].append(b - 1) - adj[b - 1].append(a - 1) - + a, b = map(int, map(int, input().strip().split())) + adj[a - 1].append(b - 1) + adj[b - 1].append(a - 1) + + def dfs(node: int): - for next_node in adj[node]: - if team[next_node]: - if team[next_node] == team[node]: - print("IMPOSSIBLE") - raise SystemExit - else: - team[next_node] = 2 if team[node] == 1 else 1 - dfs(next_node) - + for next_node in adj[node]: + if team[next_node]: + if team[next_node] == team[node]: + print("IMPOSSIBLE") + raise SystemExit + else: + team[next_node] = 2 if team[node] == 1 else 1 + dfs(next_node) + + for node in range(n): - if not team[node]: - team[node] = 1 - dfs(node) - + if not team[node]: + team[node] = 1 + dfs(node) + print(*team) ``` @@ -1252,6 +1255,7 @@ public class BuildingTeams { ```py import sys from collections import deque + input = sys.stdin.readline n, m = map(int, input().strip().split()) From c66514b5c26568c8429de104f50deb9703b47632 Mon Sep 17 00:00:00 2001 From: Jason Sun <117045786+CryoJS@users.noreply.github.com> Date: Mon, 11 Nov 2024 20:36:21 -0500 Subject: [PATCH 09/14] Update content/3_Silver/Graph_Traversal.mdx --- content/3_Silver/Graph_Traversal.mdx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index 64b58b300c..49c3581d3a 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1110,7 +1110,7 @@ def dfs(node: int): if team[next_node]: if team[next_node] == team[node]: print("IMPOSSIBLE") - raise SystemExit + exit() else: team[next_node] = 2 if team[node] == 1 else 1 dfs(next_node) @@ -1279,7 +1279,7 @@ for node in range(n): if team[next_node]: if team[next_node] == team[node]: print("IMPOSSIBLE") - raise SystemExit + exit() else: team[next_node] = 2 if team[node] == 1 else 1 queue.append(next_node) From fd29cd848f375e2f45186636e7de4545ef4316bd Mon Sep 17 00:00:00 2001 From: Kevin Sheng <55369003+SansPapyrus683@users.noreply.github.com> Date: Mon, 11 Nov 2024 20:16:16 -0800 Subject: [PATCH 10/14] Update Graph_Traversal.mdx --- content/3_Silver/Graph_Traversal.mdx | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index 49c3581d3a..ce35ef29e8 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1085,16 +1085,18 @@ public class BuildingTeams { -You have to submit with CPython (not PyPy3) to avoid exceeding the time limit. + +You have to submit with CPython (not PyPy3) to avoid TLE. + ```py import sys -input = sys.stdin.readline - sys.setrecursionlimit(int(1e9)) # disable recursion limit +input = sys.stdin.readline + n, m = map(int, input().strip().split()) adj = [[] for _ in range(n)] team = [0] * n # 0: not assigned yet, 1: team 1, 2: team 2 From f313ec6e8889b328cee194b8f8f610a8b4e3fb28 Mon Sep 17 00:00:00 2001 From: Jason Sun <117045786+CryoJS@users.noreply.github.com> Date: Mon, 18 Nov 2024 12:31:31 -0500 Subject: [PATCH 11/14] Update content/3_Silver/Graph_Traversal.mdx --- content/3_Silver/Graph_Traversal.mdx | 60 +++++++++++++++------------- 1 file changed, 32 insertions(+), 28 deletions(-) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index ce35ef29e8..3de89de83a 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1085,18 +1085,16 @@ public class BuildingTeams { - -You have to submit with CPython (not PyPy3) to avoid TLE. - +You have to submit with CPython (not PyPy3) to avoid exceeding the time limit. ```py import sys -sys.setrecursionlimit(int(1e9)) # disable recursion limit - input = sys.stdin.readline +sys.setrecursionlimit(int(1e9)) # disable recursion limit + n, m = map(int, input().strip().split()) adj = [[] for _ in range(n)] team = [0] * n # 0: not assigned yet, 1: team 1, 2: team 2 @@ -1106,7 +1104,6 @@ for _ in range(m): adj[a - 1].append(b - 1) adj[b - 1].append(a - 1) - def dfs(node: int): for next_node in adj[node]: if team[next_node]: @@ -1117,7 +1114,6 @@ def dfs(node: int): team[next_node] = 2 if team[node] == 1 else 1 dfs(next_node) - for node in range(n): if not team[node]: team[node] = 1 @@ -1255,38 +1251,46 @@ public class BuildingTeams { ```py -import sys from collections import deque -input = sys.stdin.readline +n, m = map(int, input().split()) -n, m = map(int, input().strip().split()) adj = [[] for _ in range(n)] -team = [0] * n # 0 -> has not been assigned a team yet - for _ in range(m): - a, b = map(int, map(int, input().strip().split())) + a, b = map(int, input().split()) adj[a - 1].append(b - 1) adj[b - 1].append(a - 1) -for node in range(n): - if not team[node]: - team[node] = 1 - queue = deque([node]) +assigned = [0 for _ in range(n)] +valid = True +for i in range(n): + if assigned[i] != 0: + continue - while queue: - node = queue.popleft() + assigned[i] = 1 + todo = deque([i]) + while todo: + curr = todo.popleft() + n_color = 2 if assigned[curr] == 1 else 1 + for next_ in adj[curr]: + if assigned[next_] != 0: + if assigned[next_] != n_color: + valid = False + break + else: + assigned[next_] = n_color + todo.append(next_) - for next_node in adj[node]: - if team[next_node]: - if team[next_node] == team[node]: - print("IMPOSSIBLE") - exit() - else: - team[next_node] = 2 if team[node] == 1 else 1 - queue.append(next_node) + if not valid: + break -print(*team) + if not valid: + break + +if valid: + print(*assigned) +else: + print("IMPOSSIBLE") ``` From bd92451ba6c4aef63e8d399de1c62ea87003d569 Mon Sep 17 00:00:00 2001 From: "pre-commit-ci[bot]" <66853113+pre-commit-ci[bot]@users.noreply.github.com> Date: Mon, 18 Nov 2024 17:32:43 +0000 Subject: [PATCH 12/14] [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci --- content/3_Silver/Graph_Traversal.mdx | 2 ++ 1 file changed, 2 insertions(+) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index 3de89de83a..b1b15f5cca 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1104,6 +1104,7 @@ for _ in range(m): adj[a - 1].append(b - 1) adj[b - 1].append(a - 1) + def dfs(node: int): for next_node in adj[node]: if team[next_node]: @@ -1114,6 +1115,7 @@ def dfs(node: int): team[next_node] = 2 if team[node] == 1 else 1 dfs(next_node) + for node in range(n): if not team[node]: team[node] = 1 From 369793e6fbfc12b8c72a6004e2129730811b4eed Mon Sep 17 00:00:00 2001 From: Jason Sun <117045786+CryoJS@users.noreply.github.com> Date: Mon, 18 Nov 2024 22:47:28 -0500 Subject: [PATCH 13/14] Update content/3_Silver/Graph_Traversal.mdx From faa64777e8984362b8cc15f04569349ba43502ab Mon Sep 17 00:00:00 2001 From: Kevin Sheng <55369003+SansPapyrus683@users.noreply.github.com> Date: Mon, 18 Nov 2024 20:26:14 -0800 Subject: [PATCH 14/14] Update Graph_Traversal.mdx --- content/3_Silver/Graph_Traversal.mdx | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/content/3_Silver/Graph_Traversal.mdx b/content/3_Silver/Graph_Traversal.mdx index b1b15f5cca..5766611406 100644 --- a/content/3_Silver/Graph_Traversal.mdx +++ b/content/3_Silver/Graph_Traversal.mdx @@ -1085,7 +1085,9 @@ public class BuildingTeams { -You have to submit with CPython (not PyPy3) to avoid exceeding the time limit. + +You have to submit with CPython (not PyPy3) to avoid TLE. + ```py