poj1458 LCSub 0ms 164K

#include<cstdio>
#include<cstring>
using namespace std;
//LCSub问题,水题,滚动数组优化空间
int main()
{
    char str[1005],str1[1005];
    int dp[2][1005];
    int n,m;
    while(~scanf("%s %s",str,str1))
    {
        memset(dp,0,sizeof(dp));
        n = strlen(str);
        m = strlen(str1);
        for(int i = 1; i<=n; ++i)
            for(int j = 1; j<=m; ++j)
                dp[i%2][j] = (str[i-1]==str1[j-1])?(dp[(i-1)%2][j-1] + 1):(dp[(i-1)%2][j]>dp[i%2][j-1]?dp[(i-1)%2][j]:dp[i%2][j-1]);
        printf("%d\n",dp[n%2][m]);
    }
    return 0;
}
全部评论

相关推荐

07-25 11:12
重庆大学 C++
既然这么缺人,为什么挂我呢
飞花断音:华为需要学历不高,但是很能干事儿,能吃苦也没怨言,愿意无偿加班,最好上有老下有小,不是独生子女,家庭条件不好,家在外地租房住,生活成本高,不会轻易跳槽,并且愿意接受低工资的奴仆任劳任怨地给任总的女儿买大别墅住
点赞 评论 收藏
分享
06-11 17:39
门头沟学院 Java
小呆呆的大鼻涕:卧槽,用户彻底怒了
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务