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
- re.split
- MSA
- sql 기술면접
- MySQL
- spring oauth
- springboot
- 백준 17626
- 백준 16235
- 백준 16719
- spring cloud
- with recursive
- java 기술면접
- JVM
- spring security
- Kotlin
- 웹어플리케이션 서버
- JPA
- 백준 파이썬
- 백준
- 백준 19238
- Spring
- 프로래머스
- 백준 17779
- java
- 백준 16236
- Coroutine
- 백준 15685
- 파이썬
- Spring Boot
- 프로그래머스
Archives
- Today
- Total
시작이 반
[프로그래머스] 등굣길(python 파이썬) 본문
SMALL
최단경로의 개수를 구하는 문제이다..
문제를 잘못읽어서 최단경로를 구하는 문제인줄 알았다....(몇시간을 날린건지..)
오른쪽과 아래로만 이동할 수 있다.
중학교때 배운 경로의 수 구하는 문제를 알면 풀 수 있는 문제이다.
1, x 좌표를 1로 채운다 (-1이 하나라도 있으면 그 이후에는 -1로 채운다.)
x, 1 좌표를 1로 채운다 (-1이 하나라도 있으면 그 이후에는 -1로 채운다.)
해당 좌표로 올 수 있는 경우의 수는 해당좌표의 위, 왼쪽을 더한 값이다. (-1이 있다면 -1이 아닌 값을 넣어준다.)
m, n의 좌표가 답이다.
하지만
이렇게 풀면 학교에 도착하지 못하는 경우에는 m, n 좌표에 -1이 들어간다.
예외처리를 하여 -1일경우 0을 반환해준다.
def solution(m, n, puddles):
dp = [[0] * (n + 1) for _ in range(m + 1)]
for puddle in puddles:
if puddle:
dp[puddle[0]][puddle[1]] = -1
m_one_check = False
for i in range(n + 1):
if dp[1][i] == -1:
m_one_check = True
if m_one_check:
dp[1][i] = -1
else:
dp[1][i] = 1
m_one_check = False
for i in range(1, m + 1):
if dp[i][1] == -1:
m_one_check = True
if m_one_check:
dp[i][1] = -1
else:
dp[i][1] = 1
for i in range(2, m + 1):
for j in range(2, n + 1):
if dp[i][j] == -1:
continue
else:
if dp[i - 1][j] == -1:
dp[i][j] = dp[i][j - 1]
elif dp[i][j - 1] == -1:
dp[i][j] = dp[i - 1][j]
else:
dp[i][j] = dp[i - 1][j] + dp[i][j - 1]
if dp[m][n] < 0:
return 0
return dp[m][n] % 1000000007
LIST
'알고리즘 > Programmers' 카테고리의 다른 글
[프로그래머스] 메뉴 리뉴얼(python 파이썬) (0) | 2021.03.18 |
---|---|
[프로그래머스] 신규 아이디 추천(python 파이썬) (0) | 2021.03.18 |
[프로그래머스] N으로 표현(python 파이썬) (0) | 2021.03.11 |
[프로그래머스] 정수 삼각형(python 파이썬) (0) | 2021.03.11 |
[프로그래머스] 입국심사(python 파이썬) (0) | 2021.03.11 |