我是靠谱客的博主 忧伤鸡,最近开发中收集的这篇文章主要介绍给定一个未排序数组, 找出其中最长的等差数列,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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

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

最后

以上就是忧伤鸡为你收集整理的给定一个未排序数组, 找出其中最长的等差数列的全部内容,希望文章能够帮你解决给定一个未排序数组, 找出其中最长的等差数列所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(61)

评论列表共有 0 条评论

立即
投稿
返回
顶部