给定一个未排序数组, 找出其中最长的等差数列

来源:互联网 发布:天津中兴研究所 知乎 编辑:程序博客网 时间:2024/04/29 16:03

转载请注明来自souldak,微博:@evagle

题目如题所诉:其实就是前面那篇leetcode 最长连续序列 longest consecutive sequence的升级版

leetcode上的题目是要求等差为1,即连续序列,而现在把等差为1的限制条件去掉,找最长的等差数列,做法和复杂度却升级了。

现在给出一个O(n^2)的算法:


算法思路:

先排序,O(NlogN)
从后往前,对于a[i],令 j=i+1~n-1
map[pair(a[i],a[j]-a[i])] = max(map[pair(a[j]-,a[j]-[a[i])] , 1) + 1 
其中pair(a,b)表示以a为首项,b为等差的等差数列的最长的长度
从a[n-1]一直算到a[0],所有的pair(a[k],b)都算出来了,现在只要找出其中最大的即可。

按着这个思路,代码实现也比较简单,就不上代码了。

原创粉丝点击