【Link】:

【Description】



给你两个串s1,s2;

让你生成一个串S;

使得s1和s2都是S的子列;

要求S最短;

求S的不同方案个数;

【Solution】



设两个串的长度分别为n1和n2;

则答案为n1+n2-两个串的最长公共子序列

不同的串则可以在求最长公共子序列的时候顺便求出;

设dp2[i][j],表示第一个字符串前i个字符,第二个字符串前j个字符能组成的不同的字符串的个数;

dp1[i][j]是最长公共子序列数组

如果

s1[i]==s2[j],dp2[i][j] = dp2[i-1][j-1];

(表示在dp2[i-1][j-1]所表示的所有字符串的末尾再加上一个s1[i])

s1[i]!=s2[j]:

dp1[i-1][j]>dp1[i][j-1],则dp2[i][j] = dp2[i-1][j]

(表示在dp[i-1][j]所表示的所有字符串末尾再加上一个s1[i]);

dp1[i-1][j]< dp1[i][j-1],则dp2[i][j] = dp2[i][j-1];

(同理)

dp1[i-1][j]==dp1[i][j-1],则dp2[i][j] = dp2[i][j-1]+dp2[i-1][j];

(两个都是最长的,则两个都能加上s1[i]或s2[j]组成符合要求的字符串)

有空串,用gets..



【NumberOf WA】



1



【Reviw】



最长公共子序列的变形题;



【Code】

#include <bits/stdc++.h>
using namespace std;
#define LL long long const int N = 30; char s1[N+5],s2[N+5];
LL dp1[N+5][N+5],dp2[N+5][N+5];
int n1,n2; int main(){
//freopen("F:\\rush.txt","r",stdin);
int T;
scanf("%d",&T);
getchar();
for (int ii = 1;ii <= T;ii++){
gets(s1+1);
gets(s2+1);
memset(dp1,0,sizeof dp1),memset(dp2,0,sizeof dp2);
n1 = strlen(s1+1),n2 = strlen(s2+1);
for (int i = 0;i <= n1;i++)
dp2[i][0] = 1;
for (int i = 1;i <= n2;i++)
dp2[0][i] = 1;
for (int i = 1;i <= n1;i++)
for (int j = 1;j <= n2;j++)
if (s1[i]==s2[j]){
dp1[i][j] = dp1[i-1][j-1]+1;
dp2[i][j] = dp2[i-1][j-1];
}else{
dp1[i][j] = max(dp1[i-1][j],dp1[i][j-1]);
if (dp1[i-1][j] > dp1[i][j-1])
dp2[i][j] = dp2[i-1][j];
else
if (dp1[i-1][j] < dp1[i][j-1])
dp2[i][j] = dp2[i][j-1];
else
dp2[i][j] = dp2[i-1][j] + dp2[i][j-1];
}
printf("Case #%d: %lld %lld\n",ii,(LL) n1+n2-dp1[n1][n2],dp2[n1][n2]);
}
return 0;
}

【Uva 10723】Cyborg Genes的更多相关文章

  1. 【巧妙算法系列】【Uva 11464】 - Even Parity 偶数矩阵

    偶数矩阵(Even Parity, UVa 11464) 给你一个n×n的01矩阵(每个元素非0即1),你的任务是把尽量少的0变成1,使得每个元素的上.下.左.右的元素(如果存在的话)之和均为偶数.比 ...

  2. 【贪心+中位数】【UVa 11300】 分金币

    (解方程建模+中位数求最短累积位移) 分金币(Spreading the Wealth, UVa 11300) 圆桌旁坐着n个人,每人有一定数量的金币,金币总数能被n整除.每个人可以给他左右相邻的人一 ...

  3. 【UVa 10881】Piotr's Ants

    Piotr's Ants Porsition:Uva 10881 白书P9 中文改编题:[T^T][FJUT]第二届新生赛真S题地震了 "One thing is for certain: ...

  4. 【UVa 116】Unidirectional TSP

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  5. 【UVa 1347】Tour

    [Link]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  6. 【UVA 437】The Tower of Babylon(记忆化搜索写法)

    [题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  7. 【uva 1025】A Spy in the Metro

    [题目链接]:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  8. 【Uva 11584】Partitioning by Palindromes

    [Link]:https://cn.vjudge.net/contest/170078#problem/G [Description] 给你若干个只由小写字母组成的字符串; 问你,这个字符串,最少能由 ...

  9. 【Uva 11400】Lighting System Design

    [Link]: [Description] 你要构建一个供电系统; 给你n种灯泡来构建这么一个系统; 每种灯泡有4个参数 1.灯泡的工作电压 2.灯泡的所需的电源的花费(只要买一个电源就能供这种灯泡的 ...

随机推荐

  1. wsimport 使用方法具体解释

    wsimport 使用方法 本文主要介绍wsimport的简单使用方法.帮助大家在webserviceclient开发过程中生成接口代码: 打开java JDK文件夹我们会看到wsimport工具,这 ...

  2. android mvp高速开发框架介绍(dileber使用之小工具使用)

    android mvp框架:dileber(https://github.com/dileber/dileber.git) 继续为大家介绍android mvp开源框架 dileber 官方交流qq群 ...

  3. 86.express里面的app.configure作用

    以下摘自 express 3.0 的 文档 app.configure([env], callback) Conditionally invoke callback when env matches ...

  4. Java类和对象5

    写一个Java应用程序,该应用程序包括2个类:Print类和主类E.Print类里有一个方法output()功能是输出100 ~ 999之间的所有水仙花数(各位数字的立方和等于这个三位数本身,如: 3 ...

  5. Objective-C 小记(10)__weak

    本文使用的 runtime 版本为 objc4-706. __weak 修饰的指针最重要的特性是其指向的对象销毁后,会自动置为 nil,这个特性的实现完全是依靠运行时的.实现思路是非常简单的,对于下面 ...

  6. c#做对比软件

    一些 HTML内容比较/文本差异比较 开源代码 1. DiffPlex - a .NET Diff Generator    http://diffplex.codeplex.com/SourceCo ...

  7. Layout Team

    The layout team is a long-term engineering team tasked with maintaining, supporting, and improving t ...

  8. mysql主从复制主服务器日志格式的区别

        statement(语句级别,从服务器直接把语句拿来执行):            影响一大片(插入很多条或修改很多条),就适合用 statement       row(行级别,从服务器直接 ...

  9. js数组去重问题

    1. 双层循环:外层循环,内层比较值: (1)利用splice直接在原数组进行操作 Array.prototype.delRepeat = function (){ var arr = this; v ...

  10. UVA-10200 Prime Time 素数(注意除法精度)

    题目链接:https://cn.vjudge.net/problem/UVA-10200 题意 给出一个公式$ m=n^2+n+41, n \in Z^+ $ 现在$ a,b\in[0, 10000] ...