Hiya_
๊ฐœ๋ฐœ์ž์ทจ๐ŸŒฑ
Hiya_
Github
์ „์ฒด ๋ฐฉ๋ฌธ์ž
์˜ค๋Š˜
์–ด์ œ
  • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (155) N
    • ๐Ÿ’ปBackend (1) N
      • ๋ผ์ด์ง•์บ ํ”„ (6)
      • SSAFY | ์‹ธํ”ผ (2)
      • ์‹ ํ•œDS ๊ธˆ์œตSW ์•„์นด๋ฐ๋ฏธ (2)
    • ๐Ÿ“๋ฌธ์ œ ํ’€์ด (102)
      • ๐ŸงฉBaekjoon (47)
      • ๐ŸงฉProgrammers (42)
      • ๐ŸงฉSWExpertAcademy (10)
      • ๐ŸงฉSofteer (3)
    • ๐Ÿ“‚Language (31)
      • Python (3)
      • JAVA (2)
      • SQL (6)
      • English (19)
    • โœจUseful information (5)
    • ๐Ÿ”‘Algorithms (3)
    • ๐Ÿ™Git (2)

๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

  • ํ™ˆ
  • ํƒœ๊ทธ
  • ๋ฐฉ๋ช…๋ก

๊ณต์ง€์‚ฌํ•ญ

์ธ๊ธฐ ๊ธ€

ํƒœ๊ทธ

  • ํ† ์ต๋ฌด๋ฃŒ๊ฐ•์˜
  • mysql
  • Union
  • ์˜ค๋ธ”์™„
  • ์™„์ „ํƒ์ƒ‰
  • ํ† ์ต์ ์ˆ˜
  • ๋‚ด์žฅํ•จ์ˆ˜
  • BaekJoon
  • ํ•ด์ปค์Šคํ† ์ต
  • ๊ทธ๋ฆฌ๋””
  • UNION ALL
  • ํ† ์ต๋ฌด๋ฃŒ์ž๋ฃŒ
  • ํ•ด์ปค์ŠคํŒŒ๋žญ์ด
  • sort
  • ์ •๋ ฌ
  • BFS
  • ํ† ์ต์‹œํ—˜
  • ํ† ์ต๋…ํ•™
  • ํ† ์ตRC
  • ํ‹ฐ์Šคํ† ๋ฆฌ์ฑŒ๋ฆฐ์ง€
  • ๋ฐฑ์ค€
  • ํ† ์ต๊ณต๋ถ€
  • ๊ตฌํ˜„
  • 2์ฐจ์› ๋ฐฐ์—ด
  • ํ† ์ต๊ธฐ์ถœ
  • Python
  • greedy algorithm
  • ์ฝ”ํ…Œ
  • ๋‹ค์ต์ŠคํŠธ๋ผ
  • ๋ฆฌ์ŠคํŠธ

์ตœ๊ทผ ๋Œ“๊ธ€

์ตœ๊ทผ ๊ธ€

ํ‹ฐ์Šคํ† ๋ฆฌ


Owner : ๊น€์‹ ์˜
Naver Blog

hELLO ยท Designed By ์ •์ƒ์šฐ.
Hiya_

๊ฐœ๋ฐœ์ž์ทจ๐ŸŒฑ

๐Ÿ“๋ฌธ์ œ ํ’€์ด/๐ŸงฉBaekjoon

[Python] ๋ฐฑ์ค€ 18405 ๊ฒฝ์Ÿ์  ์ „์—ผ | BFS

2023. 5. 20. 20:25

 

~๋ชฉ์ฐจ~

๋ฌธ์ œ

๋ฌธ์ œ ํ•ด๊ฒฐ ํฌ์ธํŠธ

์ž‘์„ฑ ์ฝ”๋“œ


 

๋ฌธ์ œ

https://www.acmicpc.net/problem/18405

 

18405๋ฒˆ: ๊ฒฝ์Ÿ์  ์ „์—ผ

์ฒซ์งธ ์ค„์— ์ž์—ฐ์ˆ˜ N, K๊ฐ€ ๊ณต๋ฐฑ์„ ๊ธฐ์ค€์œผ๋กœ ๊ตฌ๋ถ„๋˜์–ด ์ฃผ์–ด์ง„๋‹ค. (1 ≤ N ≤ 200, 1 ≤ K ≤ 1,000) ๋‘˜์งธ ์ค„๋ถ€ํ„ฐ N๊ฐœ์˜ ์ค„์— ๊ฑธ์ณ์„œ ์‹œํ—˜๊ด€์˜ ์ •๋ณด๊ฐ€ ์ฃผ์–ด์ง„๋‹ค. ๊ฐ ํ–‰์€ N๊ฐœ์˜ ์›์†Œ๋กœ ๊ตฌ์„ฑ๋˜๋ฉฐ, ํ•ด๋‹น ์œ„์น˜

www.acmicpc.net

 

 

๋ฌธ์ œ ํ•ด๊ฒฐ ํฌ์ธํŠธ

- ํŠน์ • ์œ„์น˜๋ฅผ ์ค‘์‹ฌ์œผ๋กœ ์ƒํ•˜์ขŒ์šฐ ๋ป—์–ด๊ฐ€๋ฏ€๋กœ BFS๊ฐ€ ์ ์ ˆ

- ์ˆซ์ž๊ฐ€ ์ž‘์€ ๋ฐ”์ด๋Ÿฌ์Šค๊ฐ€ ์šฐ์„ ๋˜์–ด์•ผ ํ•˜๋ฏ€๋กœ ๋ฆฌ์ŠคํŠธ๋กœ ๋ฐ›์•„ ์ •๋ ฌ ํ›„ ํ๋กœ ์ „ํ™˜ํ•œ๋‹ค!

- ํ์— ๊ฐ’์ด ์—†์–ด์งˆ ๋•Œ๊นŒ์ง€ ๊บผ๋‚ด ์ƒํ•˜์ขŒ์šฐ์˜ ๊ฐ ๊ฐ’์ด ๋‹ค์‹œ ํ์— ๋„ฃ๋Š” ์กฐ๊ฑด์— ๋ถ€ํ•ฉํ•˜๋Š”์ง€ ํ™•์ธํ•œ๋‹ค.

- ํ์—์„œ ๊บผ๋‚ธ ๊ฐ’์˜ ์‹œ๊ฐ„์ด S์™€ ๊ฐ™๋‹ค๋ฉด ์ข…๋ฃŒ

- X-1 ํ–‰ Y-1 ์—ด์˜ ๊ฐ’์„ ๋ฐฐ์—ด์—์„œ ๋ฐ˜ํ™˜ํ•œ๋‹ค.

 

์ž‘์„ฑ ์ฝ”๋“œ

from collections import deque
import sys
input = sys.stdin.readline

dr = [1, -1, 0, 0]  # down, up, right, left
dc = [0, 0, 1, -1]

N, K = map(int, input().split())
board = []  # ๋ฐ”์ด๋Ÿฌ์Šค ์ •๋ณด ๋ฐ›์•„์˜ฌ ๋ฐฐ์—ด
for _ in range(N):
    board.append(list(map(int, input().split())))

S, X, Y = map(int, input().split())  # ์‹œ๊ฐ„, ํ–‰, ์—ด

q = []
for i in range(N):
    for j in range(N):
        if board[i][j] != 0:  # ๋ฐ”์ด๋Ÿฌ์Šค๊ฐ€ ์žˆ๋Š” ์œ„์น˜
            q.append((board[i][j], i, j, 0))  # ๋ฐ”์ด๋Ÿฌ์Šค ์ •๋ณด, ํ–‰, ์—ด, ํ˜๋Ÿฌ๊ฐ„ ์‹œ๊ฐ„
q.sort()  # (์ฃผ์˜) ๋ฆฌ์ŠคํŠธ๋กœ ๋ฐ›์•„ ์ •๋ ฌ ํ›„ queue๋กœ ๋ณ€๊ฒฝ!
q = deque(q)

while q:  # BFS
    viru, row, col, time = q.popleft()
    if time == S:  # ์‹œ๊ฐ„์ด S๋งŒํผ ์ง€๋‚ฌ๋‹ค๋ฉด ์ข…๋ฃŒ
        break
    for d in range(4):  # ์ƒํ•˜์ขŒ์šฐ ์ด๋™
        r = row + dr[d]
        c = col + dc[d]
        if -1 < r < N and -1 < c < N and not board[r][c]:  # ๋ฒ”์œ„๋ฅผ ๋ฒ—์–ด๋‚˜์ง€ ์•Š๊ณ  ์œ„์น˜ ๊ฐ’์ด 0์ผ ๋•Œ
            board[r][c] = viru  # ๋ฐ”์ด๋Ÿฌ์Šค ๋ฐฐ์น˜
            q.append((viru, r, c, time+1))  # ๋‹ค์Œ ๋ฒˆ ์œ„์น˜๋ฅผ ํ์— ์ €์žฅ

print(board[X-1][Y-1])

 

 

 

๋„์›€์ด ๋˜์…จ๋‹ค๋ฉด ์ข‹์•„์š” ๋ˆŒ๋Ÿฌ์ฃผ์„ธ์š”๐Ÿ’š

 

 

 

'๐Ÿ“๋ฌธ์ œ ํ’€์ด > ๐ŸงฉBaekjoon' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[Python] ๋ฐฑ์ค€ 1647 ๋„์‹œ ๋ถ„ํ•  ๊ณ„ํš | ํฌ๋ฃจ์Šค์นผ ์•Œ๊ณ ๋ฆฌ์ฆ˜  (0) 2023.05.28
[Python] ๋ฐฑ์ค€ 1197 ์ตœ์†Œ ์ŠคํŒจ๋‹ ํŠธ๋ฆฌ  (0) 2023.05.23
[Python] ๋ฐฑ์ค€ 14502 ์—ฐ๊ตฌ์†Œ | BFS  (0) 2023.05.20
[Python] ๋ฐฑ์ค€ 4485 ๋…น์ƒ‰ ์˜ท ์ž…์€ ์• ๊ฐ€ ์ ค๋‹ค์ง€? | ๋‹ค์ต์ŠคํŠธ๋ผ  (0) 2023.05.18
[Python] ๋ฐฑ์ค€ 1504 ํŠน์ •ํ•œ ์ตœ๋‹จ ๊ฒฝ๋กœ | ๋‹ค์ต์ŠคํŠธ๋ผ  (0) 2023.05.17
    '๐Ÿ“๋ฌธ์ œ ํ’€์ด/๐ŸงฉBaekjoon' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • [Python] ๋ฐฑ์ค€ 1647 ๋„์‹œ ๋ถ„ํ•  ๊ณ„ํš | ํฌ๋ฃจ์Šค์นผ ์•Œ๊ณ ๋ฆฌ์ฆ˜
    • [Python] ๋ฐฑ์ค€ 1197 ์ตœ์†Œ ์ŠคํŒจ๋‹ ํŠธ๋ฆฌ
    • [Python] ๋ฐฑ์ค€ 14502 ์—ฐ๊ตฌ์†Œ | BFS
    • [Python] ๋ฐฑ์ค€ 4485 ๋…น์ƒ‰ ์˜ท ์ž…์€ ์• ๊ฐ€ ์ ค๋‹ค์ง€? | ๋‹ค์ต์ŠคํŠธ๋ผ
    Hiya_
    Hiya_
    ํ•˜์–€ ์ฒœ๊ณผ ๋ฐ”๋žŒ๋งŒ ์žˆ๋‹ค๋ฉด ์–ด๋””๋“  ๊ฐˆ ์ˆ˜ ์žˆ์–ด

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”