力扣-274. H 指数(C语言)

给你一个整数数组 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;
}

代码成绩:

力扣-274. H 指数(C语言)_第1张图片

因为我使用了哈希表作为额外空间,因此空间复杂度较高。(这就去看题解学习OVO~)

你可能感兴趣的:(leetcode,算法,数据结构)