일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 6603
- Combination
- 최소공배수
- 매일11시
- 뒤로가기
- 순열
- 백준
- LCS
- 1260
- 1182
- 9095
- expo
- 11057
- 나머지
- 11053
- Python
- 파이썬
- 11054
- permutation
- 코테
- 앱
- lcm
- itertools
- 11기
- 홈화면
- Kotlin
- 안드로이드
- 코틀린
- 괄호
- Android
- Today
- Total
목록LCS (4)
황소개발자
https://hjp845.tistory.com/30 백준 1958 파이썬 python : LCS 3 @@황소처럼 우직하게@@ 처음엔 아래 코드와 같이, a b c 의 lcs 는 (a b 의 lcs) 와 (c) 의 lcs 이겠지 생각했으나 틀렸다. def lcs(a, b): dp = [[0 for i in range(len(a) + 1)] for j in range(len(b) + 1)] for i in range(1, len(b).. hjp845.tistory.com 이전 글에서 길이를 찾아내는 문제를 풀어보았다. 이번에는 부분문자열까지 찾아내는 솔루션을 제시한다. 이런 문제가 사이트에 있을진 모르겠지만, 충분히 나올 수 있는 문제다. lst = [input() for i in range(3)] dp ..
처음엔 아래 코드와 같이, a b c 의 lcs 는 (a b 의 lcs) 와 (c) 의 lcs 이겠지 생각했으나 틀렸다. def lcs(a, b): dp = [[0 for i in range(len(a) + 1)] for j in range(len(b) + 1)] for i in range(1, len(b) + 1): for j in range(1, len(a) + 1): if a[j - 1] == b[i - 1]: dp[i][j] = dp[i - 1][j - 1] + 1 else: dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]) return findit(a, dp) def findit(a, dp): ans = '' now = dp[-1][-1] y = len(dp) - 1 ..
a = input() b = input() dp = [[0 for i in range(len(a) + 1)] for j in range(len(b) + 1)] for i in range(1, len(b) + 1): for j in range(1, len(a) + 1): if a[j - 1] == b[i - 1]: dp[i][j] = dp[i - 1][j - 1] + 1 else: dp[i][j] = max(dp[i - 1][j], dp[i][j - 1]) def findit(): ans = '' now = dp[-1][-1] y = len(dp) - 1 x = len(dp[0]) - 1 while now != 0: if dp[y][x - 1] == now - 1 and now - 1 == dp[y - 1..
기본적으로 다음과 같은 표를 만드세요 0 A C A Y K P 0 0 0 0 0 0 0 0 C 0 A 0 P 0 C 0 A 0 K 0 그리고 한줄씩 채워 나갑니다. 0 A C A Y K P 0 0 0 0 0 0 0 0 C 0 0 A 0 P 0 C 0 A 0 K 0 위에 테이블에서, C와 A를 비교하면 다르죠? 다르면 max(그 칸의 윗 칸 값, 그 칸의 왼쪽 칸 값) 을 넣어줍니다. 0 A C A Y K P 0 0 0 0 0 0 0 0 C 0 0 1 A 0 P 0 C 0 A 0 K 0 위에 테이블에서, C와 C 같죠? 같으면 (그 칸의 왼쪽 위 대각선 칸 값) 을 넣어줍니다. 이게 답니다. 한줄씩 채워나가면됩니다. a = input() b = input() dp = [[0 for i in range(le..