일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 파이썬
- KAKAO BLIND RECRUITMENT
- 정렬
- 정규식
- 위클리 챌린지
- 프로그래머스
- DateTime
- 동적 계획법
- Combinations
- 재귀함수
- dfs
- Zip
- 다익스트라
- divmod
- java
- 이분탐색
- 카카오
- 자바
- programmers
- 백준
- 수학
- Set
- heapq
- lambda
- Re
- BFS
- 추석맞이 코딩챌린지
- 그리디
- backjoon
- python
Archives
- Today
- Total
상상쓰
[프로그래머스] 9주차_전력망을 둘로 나누기 본문
https://programmers.co.kr/learn/courses/30/lessons/86971
코딩테스트 연습 - 9주차
9 [[1,3],[2,3],[3,4],[4,5],[4,6],[4,7],[7,8],[7,9]] 3 7 [[1,2],[2,7],[3,7],[3,4],[4,5],[6,7]] 1
programmers.co.kr
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