HDU 1159 最长公共子序列

#include <iostream>
#include <stdio.h>
#include <string.h>
#define MAX 501
using namespace std;

int main()
{
    //freopen("in.txt","r",stdin);
    char a[MAX],b[MAX];
    int dp[MAX][MAX];
    while(scanf("%s%s",a,b)!=EOF)
    {
        int lena=strlen(a);
        int lenb=strlen(b);
        memset(dp,0,sizeof(dp));
        for(int i=0;i<lenb;i++)
        {
            dp[0][i]=0;
        }
        for(int i=0;i<lena;i++)
        {
            dp[i][0]=0;
        }
        for(int i=1;i<=lena;i++)
        {
            for(int j=1;j<=lenb;j++)
            {
                if(a[i-1]==b[j-1])dp[i][j]=dp[i-1][j-1]+1;
                else dp[i][j]=dp[i-1][j]>dp[i][j-1]?dp[i-1][j]:dp[i][j-1];//cout<<i<<","<<j<<","<<dp[i][j]<<endl;
            }
        }
        printf("%d\n",dp[lena][lenb]);
    }
    return 0;
}

你可能感兴趣的:(HDU 1159 最长公共子序列)