Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- text-to-speech
- korean tts
- DCTTS
- Vocoder
- 한국어 tts
- melgan
- deep voice
- 트레이닝
- singing voice synthesis
- 한국어 음성 합성
- tacotron
- 딥러닝 보코더
- 학습
- 딥러닝
- 보코더
- 노래합성
- waveglow
- 윈도우
- TTS
- 음성 합성
- 딥러닝 음성 합성
- 타코트론
- YOLO
- you only look once
Archives
- Today
- Total
chldkato
백준 13460 구슬 탈출 2 (파이썬) 본문
https://www.acmicpc.net/problem/13460
1. 빨간 구슬과 파란 구슬을 기울인 방향에 대해서 갈 수 있는 만큼 이동했을 때의 좌표를 구한다
2. 중간에 파란 구슬이 구멍에 빠지면 continue하여 다른 방향으로 기울인 경우로 넘어간다
3. 빨간 구슬과 파란 구슬이 겹치면 각각 이동한 길이를 구하여 앞뒤로 위치하도록 처리한다
4. 빨간 구슬이 빠지면 기울인 횟수를 출력하고 10번이 넘어가면 -1 출력
from collections import deque
dx = [0, 0, 1, -1]
dy = [1, -1, 0, 0]
def bfs(rx, ry, bx, by, cnt):
q.append([rx, ry, bx, by])
c.append([rx, ry, bx, by])
while q:
qlen = len(q)
while qlen:
rx, ry, bx, by = q.popleft()
if a[rx][ry] == 'O':
print(cnt)
return
for i in range(4):
nrx, nry, nbx, nby = rx, ry, bx, by
while True:
nrx += dx[i]; nry += dy[i]
if a[nrx][nry] == 'O':
break
if a[nrx][nry] == '#':
nrx -= dx[i]; nry -= dy[i]
break
while True:
nbx += dx[i]; nby += dy[i]
if a[nbx][nby] == 'O':
break
if a[nbx][nby] == '#':
nbx -= dx[i]; nby -= dy[i]
break
if a[nbx][nby] == 'O':
continue
if nrx == nbx and nry == nby:
if abs(rx - nrx) + abs(ry - nry) > abs(bx - nbx) + abs(by - nby):
nrx -= dx[i]; nry -= dy[i]
else:
nbx -= dx[i]; nby -= dy[i]
if [nrx, nry, nbx, nby] not in c:
c.append([nrx, nry, nbx, nby])
q.append([nrx, nry, nbx, nby])
qlen -= 1
if cnt == 10:
print(-1)
return
cnt += 1
print(-1)
return
n, m = map(int, input().split())
a = [[] for _ in range(n)]
c, q, cnt = [], deque(), 0
for i in range(n):
a[i] = list(map(str, input()))
for j in range(m):
if a[i][j] == 'R':
rx, ry = i, j
a[i][j] = '.'
elif a[i][j] == 'B':
bx, by = i, j;
a[i][j] = '.'
bfs(rx, ry, bx, by, cnt)
'백준' 카테고리의 다른 글
백준 2206 벽 부수고 이동하기 (파이썬) (2) | 2020.02.16 |
---|---|
백준 2644 촌수계산 (파이썬) (0) | 2020.02.16 |
백준 10026 적록색약 (파이썬) (2) | 2020.02.16 |
백준 1697 숨바꼭질 (파이썬) (0) | 2020.02.16 |
백준 2468 안전 영역 (파이썬) (0) | 2020.02.16 |
Comments