Codeforces Round #156 (Div. 1) A. Almost Arithmetical Progression DP
链接:
http://codeforces.com/contest/256/problem/A
题意:
给出一个序列,求最长的子序列,满足隔位的两个数相等,问这个最长的子序列的长度是多少。
题解:
先把b数组离散化一下,dp[i][j]就表示当前循环节是i,j的最大值
代码:
31 int n; 32 int b[MAXN]; 33 int dp[MAXN][MAXN]; 34 35 int main() { 36 ios::sync_with_stdio(false), cin.tie(0); 37 cin >> n; 38 VI v; 39 rep(i, 0, n) cin >> b[i], v.pb(b[i]); 40 sort(all(v)); 41 v.erase(unique(all(v)), v.end()); 42 rep(i, 0, n) b[i] = lower_bound(all(v), b[i]) - v.begin(); 43 int m = v.size(); 44 int ans = 0; 45 rep(i, 0, n) rep(j, 0, m) { 46 int x = b[i]; 47 dp[j][x] = max(dp[j][x], dp[x][j] + 1); 48 ans = max(ans, dp[j][x]); 49 } 50 cout << ans << endl; 51 return 0; 52 }
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步