洛谷P1481 魔族密码(LIS)
程序员文章站
2022-07-05 14:31:44
题意 题目链接 给出一堆字符串,若一个串是另一个串的前缀 ,那么它们可以连接在一起 问最大的链接长度 Sol LIS沙比提其实是做完了才看出是LIS ......
题意
给出一堆字符串,若一个串是另一个串的前缀 ,那么它们可以连接在一起
问最大的链接长度
sol
lis沙比提其实是做完了才看出是lis
#include<cstdio> #include<algorithm> #include<cstring> #include<iostream> #define ll long long // #define int long long using namespace std; const int maxn = 2001, inf = 1e9 + 7, mod = 998244353; inline int read() { char c = getchar(); int x = 0, f = 1; while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();} while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar(); return x * f; } int n; string s[maxn]; int f[maxn]; bool suf(string a, string b) { int cur = 0; for(int i = 0; i < a.length(); i++) { if(a[i] != b[cur]) return 0; cur++; } return 1; } main() { cin >> n; for(int i = 1; i <= n; i++) cin >> s[i]; int ans = 0; for(int i = 1; i <= n; i++) { f[i] = 1; for(int j = 1; j < i; j++) { if(suf(s[j], s[i])) f[i] = max(f[i], f[j] + 1); } ans = max(ans, f[i]); } printf("%d", ans); return 0; } /* */
上一篇: 初学Python
下一篇: 数据库一对多,多对一, 多对多的问题