意甲冠军 是否可以由串来推断a,b字符不改变其相对为了获取字符串的组合c
本题有两种解法 DP或者DFS
考虑DP 令d[i][j]表示是否能有a的前i个字符和b的前j个字符组合得到c的前i+j个字符 值为0或者1 那么有d[i][j]=(d[i-1][j]&&a[i]==c[i+j])||(d[i][j-1]&&b[i]==c[i+j]) a,b的下标都是从1開始的 注意0的初始化
#include<cstdio> #include<cstring> using namespace std; const int N = 205; char a[N], b[N], c[2 * N]; bool d[N][N]; int main() { int cas; scanf ("%d", &cas); for (int k = 1; k <= cas; ++k) { scanf ("%s%s%s", a + 1, b + 1, c + 1); int la = strlen (a + 1), lb = strlen (b + 1), i = 1, j = 1; memset (d, 0, sizeof (d)); while (a[i] == c[i] && i <= la) d[i++][0] = true; while (b[j] == c[j] && j <= lb) d[0][j++] = true; for (int i = 1; i <= la; ++i) for (int j = 1; j <= lb; ++j) d[i][j] = ( (d[i - 1][j] && a[i] == c[i + j]) || (d[i][j - 1] && b[j] == c[i + j])); printf ("Data set %d: ", k); printf (d[la][lb] ?"yes " : "no "); } return 0; }
以下是dfs的代码 看是否能在ab中相应搜到c的每个字母就可
//DFS版 #include <cstdio> #include <cstring> using namespace std; const int N = 205; char a[N], b[N], c[2 * N]; bool vis[N][N], ans; void dfs (int i, int j, int k) { if (c[k] == '