Problem: 274. H 指数
文章目录
思路
最后的结果一定不会超过下标个数。应为文章也要大于这个h,h超过了文章总数,就永远不会存在这么多的文章满足条件,所以只需要循环下标,那么最后的结果呢?
解题方法
由于排了序,所以后面的文章引用数量一定大于等于目前的数量,能不能以文章的引用为判断呢,不能,设想6 6 6 6 6 6 6 6 6 ,如果以引用方式,我们发现我们只能判断6,但是很明显中间的6可以满足条件,因为不同的文章数量也会影响结果,所以这种思路是错的。所以目标就是,如果目前位置开始所有的文章数量比引用数量来的要小,那么就满足条件。
复杂度
时间复杂度:
O ( n l o g n ) O(nlogn) O(nlogn)
空间复杂度:
O ( n l o g n ) O(nlogn) O(nlogn)
Code
Java
class Solution {
public int hIndex(int[] citations) {
Arrays.sort(citations);
int ans=0;
for(int i = 0;i <= citations.length-1; i++){
if(citations.length-i<=citations[i]){
ans = Math.max(ans,citations.length-i);
}
}
return ans;
}
}