일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- 위클리 챌린지
- python
- lambda
- 이분탐색
- 카카오
- BFS
- Combinations
- divmod
- 정렬
- 동적 계획법
- heapq
- 그리디
- Zip
- KAKAO BLIND RECRUITMENT
- 파이썬
- 백준
- java
- 재귀함수
- DateTime
- 자바
- Re
- 다익스트라
- 수학
- dfs
- 프로그래머스
- programmers
- backjoon
- Set
- 추석맞이 코딩챌린지
- 정규식
Archives
- Today
- Total
상상쓰
[프로그래머스] 9주차_전력망을 둘로 나누기 본문
https://programmers.co.kr/learn/courses/30/lessons/86971
DFS 알고리즘으로 풀었고 리프 노드를 시작으로 하여 해당 노드의 전선 연결을 끊었을 때 남아 있는 송전탑의 개수(하위 노드의 개수 + 1)를 부모 노드의 result[] 에 더했다. (리프 노드는 result[] = 1)
만들어진 result[] 와 n - result[] 의 차이의 절대값과 result[0] 중 최솟값을 result[0] 으로 잡고 최종적으로 result[0] 을 반환한다.
from collections import defaultdict
def solution(n, wires):
answer = -1
tree = defaultdict(list)
visit = [1] + [0] * n
result = [n] + [1] * n
for wire1, wire2 in wires:
tree[wire1].append(wire2)
tree[wire2].append(wire1)
rf(tree, 1, visit, result)
answer = result[0]
return answer
def rf(tree, i, visit, result):
for wire in tree[i]:
if visit[wire] == 0:
visit[wire] = 1
rf(tree, wire, visit, result)
result[i] += result[wire]
result[0] = min(result[0], abs(len(result) - 1 - 2 * result[i]))
print(solution(9, [[1, 3], [2, 3], [3, 4], [4, 5], [4, 6], [4, 7], [7, 8], [7, 9]])) # 3
'Coding Test' 카테고리의 다른 글
[백준] 문자열 판별 (0) | 2021.10.07 |
---|---|
[백준] 5의 수난 (0) | 2021.10.06 |
[백준] 가장 긴 증가하는 부분 수열 (0) | 2021.10.04 |
[백준] 라면 사기 (Small) (2) | 2021.10.01 |
[프로그래머스] 방의 개수 (0) | 2021.09.30 |
Comments