51nod 1055 最长等差数列
题目
N个不同的正整数,找出由这些数组成的最长的等差数列。
例如:1 3 5 6 8 9 10 12 13 14
等差子数列包括(仅包括两项的不列举)
1 3 5
1 5 9 13
3 6 9 12
3 8 13
5 9 13
6 8 10 12 14
其中6 8 10 12 14最长,长度为5。
输入
第1行:N,N为正整数的数量(3 <= N <= 10000)。
第2 - N+1行:N个正整数。(2<= A[i] <= 10^9)
输出
最长等差数列的长度。
输入样例
10
1
3
5
6
8
9
10
12
13
14
输出样例
5
解题思路
这题用DP做。
用 dp[i][j] 表示以a[i], a[j] 为等差数列的前两项的等差数列的长度。
例如样例:
dp[1][2] 就是以a[1], a[2] 为前两项的等差数列的长度, 就是3,因为此等差数列为 1 3 5。
我们从后往前搜, 每次搜时设两个值l, r。l在a[i]左边, r在a[i]右边。
当 a[l] + a[r] = 2 * a[i] 时, 此等差数列的长度就+1。因为是从后往前搜, 所以以代码形式呈现出来就是 dp[l][i] = dp[i][r] + 1 。
最大的 dp[i][j] 就是最长的等差数列长度。
代码
#include <iostream>
#include <algorithm>
using namespace std;
typedef long long ll