leetcode1027

最直接的思路是三层循环,可是会超时,代码以下: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

相关文章
相关标签/搜索