#UVa:531-Compromise

灆洢 2012-04-03 08:05:23

LCS(Longest Common Subsequence)的問題,不過要輸出一組解出來。

P.S. 測資並非就只有一組兩個字串,它會有好幾組的兩個字串,Input是以EOF作為結尾。

C++(0.040)

/*******************************************************/
/* UVa 531 Compromise                                  */
/* Author: Maplewing [at] knightzone.studio            */
/* Version: 2012/04/03                                 */
/*******************************************************/
#include<iostream>
#include<cstdio>
#include<cstring>
#define MAX_NUM 105
using namespace std;

int LCS[MAX_NUM][MAX_NUM];
int dir[MAX_NUM][MAX_NUM];
bool space;

void printLCS( string s1[], string s2[], int i, int j ){
  if( i == 0 || j == 0 ) return;
  if( dir[i][j] == 1 ){
    printLCS( s1, s2, i-1, j-1 );
    if( space ) printf( " " );
    printf( "%s", s1[i].c_str() );
    space = true;
  }
  else if( dir[i][j] == 2 ) printLCS( s1, s2, i-1, j );
  else printLCS( s1, s2, i, j-1 );
}

int main(){
  string input, s1[MAX_NUM], s2[MAX_NUM];
  int s1word = 1, s2word = 1;
  int str = 0;

  while( cin >> input ){
    if( input == "#" ){
      if( str ){
        --s1word;
        --s2word;
        memset( LCS, 0, sizeof(LCS) );
        for( int i = 1 ; i <= s1word ; i++ )
          for( int j = 1 ; j <= s2word ; j++ )
            if( s1[i] == s2[j] ){
              LCS[i][j] = LCS[i-1][j-1]+1;
              dir[i][j] = 1;
            }
            else if( LCS[i-1][j] > LCS[i][j-1] ){
              LCS[i][j] = LCS[i-1][j];
              dir[i][j] = 2;
            }
            else{
              LCS[i][j] = LCS[i][j-1];
              dir[i][j] = 3;
            }

        space = false;
        printLCS( s1, s2, s1word, s2word );
        printf( "\n" );
        s1word = 1;
        s2word = 1;
      }

      str ^= 1;
      continue;
    }

    if( str ) s2[s2word++] = input;
    else s1[s1word++] = input;

  }

  return 0;
}

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *

這個網站採用 Akismet 服務減少垃圾留言。進一步瞭解 Akismet 如何處理網站訪客的留言資料