题目:
给定一个整数数组 A,返回 A 中最长等差子序列的长度。
回想一下,A 的子序列是列表 A[i_1], A[i_2], …, A[i_k] 其中 0 <= i_1 < i_2 < … < i_k <= A.length - 1。并且如果 B[i+1] - B[i]( 0 <= i < B.length - 1) 的值都相同,那么序列 B 是等差的。
示例 1:
输入:[3,6,9,12]
输出:4
解释:
整个数组是公差为 3 的等差数列。
思路:
二维动态数组
第二维为从负到正的可能等差值。判断每个值的所有可能等差情况
因为大小最大到 10000,加上正负,总计 20001
计算等差值时要加上 10000,来到中间节点
class Solution {
public int longestArithSeqLength(int[] A) {
int len = A.length;
int[][] dp = new int[len][20001];
int max = 0;
for(int i=1;i<len;i++){
for(int j=0;j<i;j++){
int div = A[i]-A[j]+10000;
if(dp[j][div]>0)
dp[i][div] = dp[i][div]>dp[j][div]+1?dp[i][div]:dp[j][div]+1;
else
dp[i][div] = 2;
max = max>dp[i][div]?max:dp[i][div];
}
}
return max;
}
}```