最直接的思路是三层循环,可是会超时,代码以下:java
1 public class Solution 2 { 3 public int LongestArithSeqLength2(int[] A) 4 { 5 var maxLength = 2; 6 var len = A.Count(); 7 for (var i = 0; i < len; i++) 8 { 9 for (var j = i + 1; j < len; j++) 10 { 11 var curmax = 2; 12 var target = A[i] - A[j]; 13 var next = A[j] - target; 14 for (var k = j + 1; k < len; k++) 15 { 16 if (A[k] == next) 17 { 18 curmax++; 19 next = A[k] - target; 20 } 21 22 } 23 maxLength = Math.Max(maxLength, curmax); 24 } 25 } 26 return maxLength; 27 } 28 }
但一样的代码,使用java实现,却能够正常提交,leetcode对这道题目的的判断机制有点奇怪。python
若是想解决超时问题,能够考虑使用哈希或者dp思想,来减小判断的时间。数组
这种题目,作起来很麻烦,看看别人的思路吧。缓存
当时没想出来怎么作,通过一段时间的练习(两个半月),从新作这道题目,顺利作出来了,说明练习仍是有效果的。spa
给出一份python的实现:code
1 class Solution: 2 def longestArithSeqLength(self, A: 'List[int]') -> int: 3 n = len(A) 4 if n == 2: 5 return 2 6 dic = {0:{0:1}} 7 longest = 0 8 for i in range(1,n): 9 if i not in dic: 10 dic[i] = {0:1} 11 for j in range(i): 12 diff = A[i] - A[j] 13 if diff not in dic[j]: 14 dic[i][diff] = 2 15 else: 16 dic[i][diff] = dic[j][diff] + 1 17 longest = max(longest,dic[i][diff]) 18 return longest
使用hash缓存以前的记录,从三层循环减小为两层循环,时间复杂度为O(n^2),可是增长了空间复杂度。典型的用空间换时间的思想。blog
dic是一个字典,key值是数组的下标,value值是一个字典类型。leetcode
这个value字典,key值是int类型,表示两项之间的差;value值是int类型,表示这个差值造成的等差数列的长度。get
所以每次循环用longest记录任意一个差值所造成的最长的等差数列的长度,即为所求。hash