BOJ 9251: LCS 찾기

HDNua의 이미지

문제 링크 - 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;
}
yukariko의 이미지

LCS의 의미를 생각해보면 두 LCS의 비교는 의미가 없습니다.
처음 LCS만 가지고 문제를 해결할 수 있습니다.
그러나 구현이 잘못된 것으로 보이는군요.
LCS의 의사코드나 예제를 잘 살펴보시길 바랍니다.

HDNua의 이미지

아무도 답글을 안 달아서 서운하던 참이었습니다. ㅎㅎ
처음 보는 개념이다보니 틀렸는 모양이네요. 다시 한 번 봐야겠습니다.

저는 이렇게 생각했습니다.

qiiiiiiiip의 이미지

$ echo "MJYAUZ MZJAWXU" | ./a.out
4
$ echo "XMJYAUZ MZJAWXU" | ./a.out
2

둘 다 4가 나와야겠지요.
a에 대한 lcs라는 것은 의미가 없습니다.

http://en.wikipedia.org/wiki/Longest_common_subsequence_problem

HDNua의 이미지

답변 감사합니다. 다시 한 번 도전해보겠습니다.

저는 이렇게 생각했습니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.