일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 라이브 아카데미
- 알고리즘
- 영어회화
- baekjoon
- IF
- 회화기초
- 백준
- 다이나믹프로그래밍
- BFS
- 일상회화
- 파이썬
- dfs
- 영어
- 회화
- 라이브아카데미
- N-Queens
- 내가 듣기로는
- Hyperledger Fabric
- Backtracking Algorithm
- 백트래킹
- python
- 영어 회화
- 관계절
- 전치사
- 정렬
- 영어회와
- 완전탐색
- 백트래킹 알고리즘
- from what i hear
- 영어기초
Archives
- Today
- Total
내 맴
[ 백준 ] 16234번 : 인구 이동 (파이썬) 본문
728x90
문제 )
https://www.acmicpc.net/problem/16234
16234번: 인구 이동
N×N크기의 땅이 있고, 땅은 1×1개의 칸으로 나누어져 있다. 각각의 땅에는 나라가 하나씩 존재하며, r행 c열에 있는 나라에는 A[r][c]명이 살고 있다. 인접한 나라 사이에는 국경선이 존재한다. 모
www.acmicpc.net
[ 풀이 IDEA ]
BFS이용해서 문제를 풀어줄 수 있다
1️⃣ BFS를 통해 열린 국경선을 체크한다. (조건: 두 나라의 인구 차이 L이상, R이하)
2️⃣ 국경이 열린 나라들의 위치를 list에 저장
3️⃣ 국경이 열린 나라들의 인구를 update
4️⃣ 국경이 열리지 않을 때까지 반복
- python code
from collections import deque
dx = [0, 0, -1, 1]
dy = [-1 ,1, 0, 0]
def bfs(i, j):
group = []
q = deque()
q.append([i, j])
group.append([i, j])
while q:
x, y = q.popleft()
for k in range(4):
nx, ny = x+dx[k], y+dy[k]
if 0 <= nx < N and 0 <= ny < N and visited[nx][ny] == 0:
if L <= abs(board[nx][ny]-board[x][y]) <= R:
group.append([nx, ny])
q.append([nx, ny])
visited[nx][ny] = 1
return group
N, L, R = map(int, input().split())
board = []
for _ in range(N):
board.append(list(map(int, input().split())))
day = 0
while True:
visited = [[0]*N for _ in range(N)]
finalflag = False
for i in range(N):
for j in range(N):
if visited[i][j] == 0:
visited[i][j] = 1
# 열린 국경선 체크하고 위치 반환
group = bfs(i,j)
# 국경이 열린 나라들의 인구를 update
if len(group) > 1:
finalflag = True
change_value = sum([board[x][y] for x,y in group]) // len(group)
for x, y in group:
board[x][y] = change_value
# 국경이 열리지 않을 때까지 반복
if not finalflag:
break
day+=1
print(day)
728x90
'Algorithm > Baekjoon 문제풀이' 카테고리의 다른 글
[ 백준 ] 5972번 : 택배 배송 (파이썬) (0) | 2023.02.08 |
---|---|
[ 백준 ] 20437번 : 문자열 게임 2 (파이썬) (0) | 2023.01.16 |
[ 백준 ] 3197번 : 백조의 호수 (파이썬) (0) | 2022.12.28 |
[ 백준 ] 1987번 : 알파벳 (BFS / 파이썬) (0) | 2022.12.27 |
[ 백준 ] 14658번 : 하늘에서 별똥별이 빗발친다 (파이썬) (0) | 2022.12.27 |