您的位置:首页 > 其它

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

2013-09-11 09:29 295 查看
转载请注明来自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)都算出来了,现在只要找出其中最大的即可。

按着这个思路,代码实现也比较简单,就不上代码了。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  最长等差数列
相关文章推荐