C ++中最长的算术序列
假设我们有一个整数数组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时,序列B是算术的)<=i<B.length-1)。因此,如果输入类似于[9,4,7,2,10],则输出将为3。最长的子序列为[4,7,10]。
为了解决这个问题,我们将遵循以下步骤-
制作映射dp,n:=A的大小,设置ret:=2
对于i,范围为0至n–1
差异:=A[j]–A[i]
dp[i,diff]:=1+dp[j,diff]
ret:=1+dp[i,diff]的最大值,然后ret
对于0到i–1范围内的j
返回ret
让我们看下面的实现以更好地理解-
示例
#include <bits/stdc++.h> using namespace std; class Solution { public: int longestArithSeqLength(vector<int>& A) { unordered_map <int, unordered_map <int, int> > dp; int n = A.size(); int ret = 2; for(int i = 0; i < n; i++){ for(int j = 0; j < i; j++){ int diff = A[j] - A[i]; dp[i][diff] = 1 + dp[j][diff]; ret = max(1 + dp[i][diff], ret); } } return ret; } }; main(){ vector<int> v1 = {9,4,7,2,10}; Solution ob; cout << (ob.longestArithSeqLength(v1)); }
输入值
[9,4,7,2,10]
输出结果
3