给你一个整数数组 citations
,其中 citations[i]
表示研究者的第 i
篇论文被引用的次数。计算并返回该研究者的 h
指数。
根据维基百科上 h 指数的定义:h
代表“高引用次数” ,一名科研人员的 h
指数 是指他(她)至少发表了 h
篇论文,并且每篇论文 至少 被引用 h
次。如果 h
有多种可能的值,h
指数 是其中最大的那个。
示例 1:
输入:citations = [3,0,6,1,5]
输出:3
解释:给定数组表示研究者总共有 5篇论文,每篇论文相应的被引用了 3, 0, 6, 1, 5次。由于研究者有 3 篇论文每篇 至少被引用了3次,其余两篇论文每篇被引用不多于3次,所以她的h指数是3。
示例 2:
输入:citations = [1,3,1] 输出:1
提示:
n == citations.length
1 <= n <= 5000
0 <= citations[i] <= 1000
通过次数:91K 提交次数:203.5K 通过率:44.7%
思路(哈希表):
对于给定的数组,开辟一个哈希表用以存放论文被引用的次数。下标表示发表的论文数,值为这个数量的论文被引用的次数。例如一篇论文被引用了5次,则哈希表的小标从1到5都加1。
例如citations=[3,0,6,1,5]。初始化一个哈希表hash[6],citations的值为3时,hash从1到3都加1;citations的值为0时,hash不变;citations的值为6时,hash从1到5都加1(因为最大的论文发表数为5,我们不需要考虑到6);citations的值为1时,hash的1加1;citations的值为5时,hash从1到5都加1。得到的哈希表值为[4,3,3,2,2]。易得h=3。
代码如下:
int hIndex(int* citations, int citationsSize){
int hash[citationsSize+1];
for(int i = 1;i <= citationsSize;i++){
//初始化hash表
hash[i] = 0;
}
int j = -1;
for(int i = 0;i < citationsSize;i++){
//对小于等于citations[i]的hash下标全部加一
j = citations[i];
if(j>citationsSize){
//当citations[i]的值超过n时,令j=citationsSize
j = citationsSize;
}
while(j){
//hash下标全部加一
hash[j]++;
j--;
}
}
int result = 0;
for(int i = 1;i <= citationsSize;i++){
//找到符合条件的值
if(i>hash[i]){
break;
}
result++;
}
// printf("%d ",result);
return result;
}
代码成绩:
因为我使用了哈希表作为额外空间,因此空间复杂度较高。(这就去看题解学习OVO~)