[BOJ][๐ก3][๋ฐฑ์ค#16236] ์๊ธฐ ์์ด
์์ฑ:    
์ ๋ฐ์ดํธ:
์นดํ ๊ณ ๋ฆฌ: BOJ Gold III
๋ฌธ์ ์ถ์ฒ
๋ฌธ์
NรN ํฌ๊ธฐ์ ๊ณต๊ฐ์ ๋ฌผ๊ณ ๊ธฐ M๋ง๋ฆฌ์ ์๊ธฐ ์์ด 1๋ง๋ฆฌ๊ฐ ์๋ค. ๊ณต๊ฐ์ 1ร1 ํฌ๊ธฐ์ ์ ์ฌ๊ฐํ ์นธ์ผ๋ก ๋๋์ด์ ธ ์๋ค. ํ ์นธ์๋ ๋ฌผ๊ณ ๊ธฐ๊ฐ ์ต๋ 1๋ง๋ฆฌ ์กด์ฌํ๋ค. ์๊ธฐ ์์ด์ ๋ฌผ๊ณ ๊ธฐ๋ ๋ชจ๋ ํฌ๊ธฐ๋ฅผ ๊ฐ์ง๊ณ ์๊ณ , ์ด ํฌ๊ธฐ๋ ์์ฐ์์ด๋ค. ๊ฐ์ฅ ์ฒ์์ ์๊ธฐ ์์ด์ ํฌ๊ธฐ๋ 2์ด๊ณ , ์๊ธฐ ์์ด๋ 1์ด์ ์ํ์ข์ฐ๋ก ์ธ์ ํ ํ ์นธ์ฉ ์ด๋ํ๋ค. ์๊ธฐ ์์ด๋ ์์ ์ ํฌ๊ธฐ๋ณด๋ค ํฐ ๋ฌผ๊ณ ๊ธฐ๊ฐ ์๋ ์นธ์ ์ง๋๊ฐ ์ ์๊ณ , ๋๋จธ์ง ์นธ์ ๋ชจ๋ ์ง๋๊ฐ ์ ์๋ค. ์๊ธฐ ์์ด๋ ์์ ์ ํฌ๊ธฐ๋ณด๋ค ์์ ๋ฌผ๊ณ ๊ธฐ๋ง ๋จน์ ์ ์๋ค. ๋ฐ๋ผ์, ํฌ๊ธฐ๊ฐ ๊ฐ์ ๋ฌผ๊ณ ๊ธฐ๋ ๋จน์ ์ ์์ง๋ง, ๊ทธ ๋ฌผ๊ณ ๊ธฐ๊ฐ ์๋ ์นธ์ ์ง๋๊ฐ ์ ์๋ค. ์๊ธฐ ์์ด๊ฐ ์ด๋๋ก ์ด๋ํ ์ง ๊ฒฐ์ ํ๋ ๋ฐฉ๋ฒ์ ์๋์ ๊ฐ๋ค.
๋ ์ด์ ๋จน์ ์ ์๋ ๋ฌผ๊ณ ๊ธฐ๊ฐ ๊ณต๊ฐ์ ์๋ค๋ฉด ์๊ธฐ ์์ด๋ ์๋ง ์์ด์๊ฒ ๋์์ ์์ฒญํ๋ค. ๋จน์ ์ ์๋ ๋ฌผ๊ณ ๊ธฐ๊ฐ 1๋ง๋ฆฌ๋ผ๋ฉด, ๊ทธ ๋ฌผ๊ณ ๊ธฐ๋ฅผ ๋จน์ผ๋ฌ ๊ฐ๋ค. ๋จน์ ์ ์๋ ๋ฌผ๊ณ ๊ธฐ๊ฐ 1๋ง๋ฆฌ๋ณด๋ค ๋ง๋ค๋ฉด, ๊ฑฐ๋ฆฌ๊ฐ ๊ฐ์ฅ ๊ฐ๊น์ด ๋ฌผ๊ณ ๊ธฐ๋ฅผ ๋จน์ผ๋ฌ ๊ฐ๋ค.
๊ฑฐ๋ฆฌ๋ ์๊ธฐ ์์ด๊ฐ ์๋ ์นธ์์ ๋ฌผ๊ณ ๊ธฐ๊ฐ ์๋ ์นธ์ผ๋ก ์ด๋ํ ๋, ์ง๋์ผํ๋ ์นธ์ ๊ฐ์์ ์ต์๊ฐ์ด๋ค. ๊ฑฐ๋ฆฌ๊ฐ ๊ฐ๊น์ด ๋ฌผ๊ณ ๊ธฐ๊ฐ ๋ง๋ค๋ฉด, ๊ฐ์ฅย ์์ ์๋ ๋ฌผ๊ณ ๊ธฐ, ๊ทธ๋ฌํ ๋ฌผ๊ณ ๊ธฐ๊ฐ ์ฌ๋ฌ๋ง๋ฆฌ๋ผ๋ฉด, ๊ฐ์ฅ ์ผ์ชฝ์ ์๋ ๋ฌผ๊ณ ๊ธฐ๋ฅผ ๋จน๋๋ค.
์๊ธฐ ์์ด์ ์ด๋์ 1์ด ๊ฑธ๋ฆฌ๊ณ , ๋ฌผ๊ณ ๊ธฐ๋ฅผ ๋จน๋๋ฐ ๊ฑธ๋ฆฌ๋ ์๊ฐ์ ์๋ค๊ณ ๊ฐ์ ํ๋ค. ์ฆ, ์๊ธฐ ์์ด๊ฐ ๋จน์ ์ ์๋ ๋ฌผ๊ณ ๊ธฐ๊ฐ ์๋ ์นธ์ผ๋ก ์ด๋ํ๋ค๋ฉด, ์ด๋๊ณผ ๋์์ ๋ฌผ๊ณ ๊ธฐ๋ฅผ ๋จน๋๋ค. ๋ฌผ๊ณ ๊ธฐ๋ฅผ ๋จน์ผ๋ฉด, ๊ทธ ์นธ์ ๋น ์นธ์ด ๋๋ค. ์๊ธฐ ์์ด๋ ์์ ์ ํฌ๊ธฐ์ ๊ฐ์ ์์ ๋ฌผ๊ณ ๊ธฐ๋ฅผ ๋จน์ ๋ ๋ง๋ค ํฌ๊ธฐ๊ฐ 1 ์ฆ๊ฐํ๋ค. ์๋ฅผ ๋ค์ด, ํฌ๊ธฐ๊ฐ 2์ธ ์๊ธฐ ์์ด๋ ๋ฌผ๊ณ ๊ธฐ๋ฅผ 2๋ง๋ฆฌ ๋จน์ผ๋ฉด ํฌ๊ธฐ๊ฐ 3์ด ๋๋ค. ๊ณต๊ฐ์ ์ํ๊ฐ ์ฃผ์ด์ก์ ๋, ์๊ธฐ ์์ด๊ฐ ๋ช ์ด ๋์ ์๋ง ์์ด์๊ฒ ๋์์ ์์ฒญํ์ง ์๊ณ ๋ฌผ๊ณ ๊ธฐ๋ฅผ ์ก์๋จน์ ์ย ์๋์ง ๊ตฌํ๋ ํ๋ก๊ทธ๋จ์ ์์ฑํ์์ค.
์ ๋ ฅ
์ฒซ์งธ ์ค์ ๊ณต๊ฐ์ ํฌ๊ธฐ N(2ย โค N โค 20)์ด ์ฃผ์ด์ง๋ค. ๋์งธ ์ค๋ถํฐ N๊ฐ์ ์ค์ ๊ณต๊ฐ์ ์ํ๊ฐ ์ฃผ์ด์ง๋ค. ๊ณต๊ฐ์ ์ํ๋ 0, 1, 2, 3, 4, 5, 6, 9๋ก ์ด๋ฃจ์ด์ ธ ์๊ณ , ์๋์ ๊ฐ์ ์๋ฏธ๋ฅผ ๊ฐ์ง๋ค.
0: ๋น ์นธ 1, 2, 3, 4, 5, 6: ์นธ์ ์๋ ๋ฌผ๊ณ ๊ธฐ์ ํฌ๊ธฐ 9: ์๊ธฐ ์์ด์ ์์น
์๊ธฐ ์์ด๋ ๊ณต๊ฐ์ ํ ๋ง๋ฆฌ ์๋ค.
์ถ๋ ฅ
์ฒซ์งธ ์ค์ ์๊ธฐ ์์ด๊ฐ ์๋ง ์์ด์๊ฒ ๋์์ ์์ฒญํ์ง ์๊ณ ๋ฌผ๊ณ ๊ธฐ๋ฅผ ์ก์๋จน์ ์ ์๋ ์๊ฐ์ ์ถ๋ ฅํ๋ค.
์์
์์ 1
์ ๋ ฅ
3
0 0 0
0 0 0
0 9 0
์ถ๋ ฅ
0
์์ 2
์ ๋ ฅ
3
0 0 1
0 0 0
0 9 0
์ถ๋ ฅ
3
์์ 3
์ ๋ ฅ
4
4 3 2 1
0 0 0 0
0 0 9 0
1 2 3 4
์ถ๋ ฅ
14
์์ 4
์ ๋ ฅ
6
5 4 3 2 3 4
4 3 2 3 4 5
3 2 9 5 6 6
2 1 2 3 4 5
3 2 1 6 5 4
6 6 6 6 6 6
์ถ๋ ฅ
60
์์ 5
์ ๋ ฅ
6
6 0 6 0 6 1
0 0 0 0 0 2
2 3 4 5 6 6
0 0 0 0 0 2
0 2 0 0 0 0
3 9 3 0 0 1
์ถ๋ ฅ
48
์์ 6
์ ๋ ฅ
6
1 1 1 1 1 1
2 2 6 2 2 3
2 2 5 2 2 3
2 2 2 4 6 3
0 0 0 0 0 6
0 0 0 0 0 9
์ถ๋ ฅ
39
My Sol
from collections import deque
def find_shark():
global mat, N, ki, kj
for i in range(N):
for j in range(N):
if mat[i][j] == 9:
ki, kj = i, j
return
def find_target():
global N, mat, time
global ki, kj, k_size, k_stack
ti = tj = min_dis = 500
mi, mj = ki, kj
visit = [[0]*N for _ in range(N)]
visit[mi][mj] = 1
Q = deque()
Q.append((0, mi, mj))
while Q:
m_dis, mi, mj = Q.popleft()
# ํ์ฌ ์ต์ ๊ธธ์ด๋ณด๋ค ๊ธธ๋ฉด continue
if m_dis > min_dis: continue
for di, dj in [(-1,0),(0,-1),(0,1),(1,0)]:
si, sj = mi+di, mj+dj
# ๋ฒ์๋ฅผ ๋์ด์๋ฉด continue
if not (0<=si<N and 0<=sj<N): continue
# ๋ฐฉ๋ฌธํ๋ค๋ฉด continue
if visit[si][sj]: continue
# ํฌ๊ธฐ๊ฐ ๋ ํฌ๋ค๋ฉด continue
if mat[si][sj] > k_size: continue
visit[si][sj] = 1
# ํฌ๊ธฐ๊ฐ 0์ด๊ฑฐ๋ ์์ด์ ๊ฐ๋ค๋ฉด ๊ทธ๋ฅ ๊ธธ์ด๋ฏ๋ก visit ์ฒ๋ฆฌ ํ Q์ ๋ฃ์
if not mat[si][sj] or mat[si][sj] == k_size:
Q.append((m_dis+1, si, sj))
# ํฌ๊ธฐ๊ฐ ๋ ์๋ค๋ฉด
else:
# min_dis์ m_dis+1 ๋น๊ตํด์ ๋ ํฌ๋ฉด ์๋ฏธ ์์ผ๋ฏ๋ก continue
if min_dis < m_dis+1: continue
# min_dis์ m_dis+1 ๋น๊ตํด์ ๋ ์์ผ๋ฉด min_dis ๊ฐฑ์ ํ ์๊ฐ ํ๊ฒ
if min_dis > m_dis+1:
min_dis = m_dis+1
ti, tj = si, sj
# ๊ฐ์ผ๋ฉด ti, tj ๋น๊ตํด์ ๋์กฐ
else:
ti, tj = sorted([(si, sj), (ti, tj)])[0]
# ti, tj๊ฐ ์ด๊ธฐ๊ฐ์ด๋ผ๋ฉด ๊ฐ๋ฅํ target์ด ์์ผ๋ฏ๋ก ์ง์ ๊ฐ์ผ ํจ
if ti==tj==500: return False
# target ๋จน์ผ๋ฌ ์ด๋
time += min_dis
ki, kj = ti, tj
mat[ti][tj] = 0
k_stack += 1
if k_stack==k_size:
k_size += 1
k_stack = 0
return True
N = int(input())
mat = [list(map(int, input().split())) for _ in range(N)]
k_size = 2
k_stack, ki, kj = 0, 0, 0
find_shark()
time = 0
mat[ki][kj] = 0
while True:
if not find_target(): break
print(time)
์ ์ฐจ์ ๋ฐ๋ผ ๊ตฌํํ๋ฉด ๋๋ ๋จ์ํ ๊ตฌํ๋ฌธ์ ์๋ค.
๊ฒฐ๊ณผ
๋ง์์ต๋๋ค!!
๋๊ธ๋จ๊ธฐ๊ธฐ