我是靠谱客的博主 畅快麦片,最近开发中收集的这篇文章主要介绍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 }
转载于:https://www.cnblogs.com/baocong/p/7347303.html
最后
以上就是畅快麦片为你收集整理的Codeforces Round #156 (Div. 1) A. Almost Arithmetical Progression DP的全部内容,希望文章能够帮你解决Codeforces Round #156 (Div. 1) A. Almost Arithmetical Progression DP所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复