logo头像
Snippet 博客主题

【Leetcode 275】H-IndexII

难度: 中等(Medium)

题目

Follow up for H-Index: What if the citations array is sorted in ascending order? Could you optimize your algorithm?

思路

&#160;&#160;&#160;&#160;首先根据引用次数将输入排序,对于其中的第i个元素,它的引用次数为a[i],它右边的元素个数为j。如果j==a[i],那么这个就是所求,因为对于i右边的元素,比他们大的元素个数一定小于j;而对于i左面的元素,元素的值又一定比a[i]小。如果j>a[i],可知此时至少有a[i]个元素大于a[i],但是在i的右边可能有更好的解。如果j<a[i],可知此时至少有j个元素大于j,但是在i的左边可能有更好的解。

代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
class Solution(object):

def binary_search(self, citations, l, r):
if l > r:
return 0
m = l + (r-l)/2
if citations[m] == len(citations)-m:
return citations[m]
elif citations[m] > len(citations)-m:
return max(self.binary_search(citations, l, m-1), len(citations)-m)
else:
return max(self.binary_search(citations, m+1, r), citations[m])

def hIndex(self, citations):
"""
:type citations: List[int]
:rtype: int
"""
if citations==None or len(citations)==0:
return 0
return self.binary_search(citations,0,len(citations)-1)

评论系统未开启,无法评论!