BOJ 9251: LCS 찾기
글쓴이: HDNua / 작성시간: 금, 2014/12/26 - 7:17오후
문제 링크 - https://www.acmicpc.net/problem/9251
printf로 찍어보니 매번 각각의 LCS는 잘 찾아내는 것 같은데
시간 초과도 아니고 아예 틀렸다고 나오니 어느 부분에 문제가 있는지 궁금합니다.
a에 대해 lcs, b에 대해 lcs를 각각 구하고 두 lcs의 길이를 비교해서 풀었는데 틀렸네요..
어떤 입력에서 오류가 나는지 알 수 있을까요?
이 질문은 Baekjoon Online Judge 질문 게시판에 먼저 올렸다가 답변이 없어서 올리는 것입니다.
#include <stdio.h> #define MAX_BUFFER_LEN 1001 int main(void) { char a[MAX_BUFFER_LEN] = ""; char b[MAX_BUFFER_LEN] = ""; char lcs1[MAX_BUFFER_LEN] = ""; char lcs2[MAX_BUFFER_LEN] = ""; char *ap, *bp, *lp; int prev; int len1, len2; scanf("%s %s", a, b); lp = lcs1; for (ap=a, prev=0; *ap; ++ap) { for (bp=b+prev; *bp; ++bp) { if (*ap == *bp) { *lp++ = *bp; prev = bp - b + 1; // printf("%s\n", lcs1); break; } } } len1 = lp - lcs1; lp = lcs2; for (ap=b, prev=0; *ap; ++ap) { for (bp=a+prev; *bp; ++bp) { if (*ap == *bp) { *lp++ = *bp; prev = bp - a + 1; // printf("%s\n", lcs2); break; } } } len2 = lp - lcs2; printf("%d", (len1 < len2) ? len2 : len1); return 0; }
Forums:
LCS의 의미를 생각해보면 두 LCS의 비교는 의미가
LCS의 의미를 생각해보면 두 LCS의 비교는 의미가 없습니다.
처음 LCS만 가지고 문제를 해결할 수 있습니다.
그러나 구현이 잘못된 것으로 보이는군요.
LCS의 의사코드나 예제를 잘 살펴보시길 바랍니다.
답변 감사합니다.
아무도 답글을 안 달아서 서운하던 참이었습니다. ㅎㅎ
처음 보는 개념이다보니 틀렸는 모양이네요. 다시 한 번 봐야겠습니다.
저는 이렇게 생각했습니다.
$ echo "MJYAUZ MZJAWXU" |
둘 다 4가 나와야겠지요.
a에 대한 lcs라는 것은 의미가 없습니다.
http://en.wikipedia.org/wiki/Longest_common_subsequence_problem
아하 문장의 최대 길이를 찾지 않았군요
답변 감사합니다. 다시 한 번 도전해보겠습니다.
저는 이렇게 생각했습니다.
댓글 달기