일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- spring reactive programming
- spring webflux
- str_to_date
- JSONObject 분할
- date_format
- 스프링 리액티브 프로그래밍
- ChainedTransactionManager #분산데이터베이스 #Spring Boot #MyBatis
- JSON 분할
- 스프링 배치 공식문서
- 마리아디비
- JSONArray 분할
- batchInsert
- nonblocking
- 폐기하기
- jar 소스보기
- 스테이지에 올리기
- Meta Table
- org.json
- 스프링 배치 메타 테이블
- 날짜형을 문자형으로
- 마이바티스 트랜잭션
- git stage
- 스프링 웹플럭스
- 문자형을 날짜형으로
- 성능개선
- JSON 분해
- 무시하기
- multi update
- JobExecutionAlreadyRunningException
- JSON 분리
- Today
- Total
ebson
boj.kr/16236 아기 상어 (gold3) 파이썬 풀이 본문
1. 아기상어 최초 위치 찾기
2 먹을 수 있는 상어가 없을 때가지 아래를 반복
3. bfs 방식으로 현재 아기상어 크기로 먹을 수 있는 상어 리스트 찾기
4. bfs 방식으로 찾은 먹은 상어 리스트를 거리 오름차순, 위, 왼쪽 순으로 정렬
5. 상어 먹은 cnt를 1 증가하고 현재 아기 상어 사이즈와 같으면 아기 상어 사이즈를 1 증가
6. 먹은 상어 리스트의 첫번째 상어 좌표의 값을 0으로 저장
7. 먹은 상어 리스트의 첫번째 상어까지 거리를 ans 값에 더하기
8. 먹은 상어 리스트의 크기가 0이면 ans 값을 출력
bfs 내부에서 대부분 처리하려고 풀이한 결과 일부 테스트 케이스에서만 통과했다. 정답 풀이 참고해 위 순서로 풀이해 성공했다.
N = int(input())
board = [list(map(int, input().split())) for _ in range(N)]
shark_size = 2
shark_eat_cnt = 0
from collections import deque
dy = (-1, 0, 0, 1)
dx = (0, -1, 1, 0)
def bfs(y, x):
chk = [[0] * N for _ in range(N)]
global shark_size
dq = deque()
dq.append((y, x))
eat_list = []
while dq:
(y, x) = dq.popleft()
for i in range(4):
ny = y + dy[i]
nx = x + dx[i]
if 0<=ny<N and 0<=nx<N and board[ny][nx]<=shark_size and chk[ny][nx] == 0:
chk[ny][nx] = chk[y][x] + 1
dq.append((ny, nx))
if 0 < board[ny][nx] < shark_size:
eat_list.append((ny, nx, chk[ny][nx]))
eat_list.sort(key=lambda x: (x[2], x[0], x[1]))
return eat_list
ans = 0
def eat_shark():
for y in range(N):
for x in range(N):
if board[y][x] == 9:
ny = y
nx = x
board[y][x] = 0
while True:
global ans
global shark_eat_cnt
global shark_size
eat_list = bfs(ny, nx)
if len(eat_list) == 0:
break
else:
(ny, nx, distance) = eat_list[0]
shark_eat_cnt += 1
if shark_size == shark_eat_cnt:
shark_size += 1
shark_eat_cnt = 0
board[ny][nx] = 0
ans += distance
return ans
print(eat_shark())
bfs를 여러번 돌린다고 무조건 시간초과 나지 않는다. 문제 조건을 보고 bfs 내부에서 해결되지 않는 조건을 순서대로 처리한다.
[ 위 풀이를 더 간소화한 코드 ]
1. 아기상어 위치 찾기
2. 아기상어가 먹을 수 있는 물고기가 없을 때까지 아래를 반복
2.1. 아기상어의 좌표를 방문체크
2.2. 아기상어의 좌표값을 0으로 갱신
2.3. bfs 방식으로 아기상어가 먹을 수 있는 물고기의 좌표와 그 좌표까지의 최단거리를 fishes에 저장
2.4. fishes를 거리, y좌표, x좌표 오름차순으로 정렬
2.5. fishes의 0번째 fish의 최단거리만큼 소요시간 변수에 증감하고 아기 상어의 좌표를 fish 좌표로 갱신
2.6. 아기상어가 먹은 물고기 개수를 증감하고 아기상어의 크기만큼 먹었으면 크기를 1증감 및 물고기 개수를 0으로 갱신
2.7. fishes를 빈 배열로 갱신
3 소요시간 변수값을 출력
N = int(input())
graph = [list(map(int, input().split())) for _ in range(N)]
for y in range(N):
for x in range(N):
if graph[y][x] == 9:
(sy, sx) = (y, x)
dy = (0, 0, -1, 1)
dx = (-1, 1, 0, 0)
from collections import deque
fishes = []
def set_fishes(py, px):
dq = deque()
dq.append((py, px, 0))
while dq:
(y, x, d) = dq.popleft()
for i in range(4):
ny = y + dy[i]
nx = x + dx[i]
if 0<=ny<N and 0<=nx<N and visited[ny][nx] == 0:
visited[ny][nx] += 1
if graph[ny][nx] == 0 or graph[ny][nx] == shark_size:
dq.append((ny, nx, d+1))
elif graph[ny][nx] < shark_size:
fishes.append((ny, nx, d+1))
fishes.sort(key = lambda x: (x[2], x[0], x[1]))
sec = 0
shark_size = 2
eat_cnt = 0
while True:
visited = [[0] * N for _ in range(N)]
visited[sy][sx] += 1
graph[sy][sx] = 0
set_fishes(sy, sx)
if len(fishes) == 0:
break
else:
sec += fishes[0][2]
sy = fishes[0][0]
sx = fishes[0][1]
eat_cnt += 1
if eat_cnt == shark_size:
shark_size += 1
eat_cnt = 0
fishes = []
print(sec)
bfs방식을 사용하는 이유는 먹을 수 있는 물고기 좌표까지의 최단거리를 함께 저장하기 위함이다.
'ALGORITHM STUDY WITH PYTHON > BFS | DFS' 카테고리의 다른 글
boj.kr/13549 숨바꼭질 3 (gold5) 파이썬 풀이 (0) | 2023.04.29 |
---|---|
boj.kr/1389 케빈 베이컨의 6단계 법칙 (silver1) 파이썬 풀이 (0) | 2023.04.29 |
boj.kr/2583 영역 구하기 (silver1) 파이썬 풀이 (0) | 2023.04.27 |
boj.kr/11403 경로 찾기 (silver1) 파이썬 풀이 (0) | 2023.04.27 |
boj.kr/2206 벽 부수고 이동하기 (gold3) 파이썬 풀이 (0) | 2023.04.26 |