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
- 음성 합성
- Vocoder
- 한국어 tts
- 딥러닝
- 학습
- 노래합성
- 윈도우
- 보코더
- singing voice synthesis
- tacotron
- waveglow
- YOLO
- deep voice
- korean tts
- you only look once
- melgan
- 딥러닝 음성 합성
- DCTTS
- 트레이닝
- text-to-speech
- 한국어 음성 합성
- 타코트론
- 딥러닝 보코더
- TTS
Archives
- Today
- Total
chldkato
백준 15684 사다리 조작 (파이썬) 본문
https://www.acmicpc.net/problem/15684
1. 연결을 저장하는 리스트 a를 만든다
a는 2차 리스트인데 a[세로][가로] 로 사용한다
따라서 a의 크기는 n x h이다
2. a에 연결 관계를 저장한다
a[y-1][x-1]은 y-1번째 세로일 때 x-1번째 가로에서 x번째 가로로 이동할 수 있음을 의미한다
3. dfs로 구현한 조합으로 어느 가로선을 연결할 지 정한다
4. dfs에서 연결할 선을 고를 때 다른 가로선과 이어지면 안되는 조건을 고려해야한다
현재 위치를 세로j , 가로i 라고 할 때 j-1번 째 세로와 j+1번 째 세로에 연결된 가로선이 있는지 확인한다
5. 연결할 가로선을 모두 고르면 move 함수를 실행해서 출발한 세로선과 도착한 세로선의 인덱스가 같은지 확인한다
6. 만일 같으면 ans에 가로선을 고른 개수를 저장하고 return한다
7. ans가 값이 변했으면 ans을 출력하고 종료한다
import sys
input = sys.stdin.readline
def move():
for i in range(n):
num = i
for j in range(h):
if a[num][j]:
num += 1
elif a[num-1][j]:
num -= 1
if i != num:
return 0
return 1
def dfs(cnt, idx, r):
global ans
if cnt == r:
if move():
ans = cnt
return
for i in range(idx, h):
for j in range(n-1):
if a[j][i]:
continue
if j - 1 >= 0 and a[j-1][i]:
continue
if j + 1 < n and a[j+1][i]:
continue
a[j][i] = 1
dfs(cnt + 1, i, r)
a[j][i] = 0
n, m, h = map(int, input().split())
a = [[0]*h for _ in range(n)]
for _ in range(m):
x, y = map(int, input().split())
a[y-1][x-1] = 1
ans, flag = sys.maxsize, 1
for r in range(4):
dfs(0, 0, r)
if ans != sys.maxsize:
print(ans)
flag = 0
break
if flag:
print(-1)
'백준' 카테고리의 다른 글
백준 14891 톱니바퀴 (파이썬) (0) | 2020.04.16 |
---|---|
백준 15683 감시 (파이썬) (0) | 2020.04.16 |
백준 15685 드래곤 커브 (파이썬) (0) | 2020.04.14 |
백준 15686 치킨 배달 (파이썬) (0) | 2020.04.14 |
백준 5373 큐빙 (파이썬) (0) | 2020.04.14 |
Comments