力扣网编程274题:H指数之普通解法(中等)

一. 简介

本文记录力扣网上涉及数组,排序方面的编程题:H指数。

二. 力扣网编程274题:H指数(中等)

给你一个整数数组 citations ,其中 citations[i] 表示研究者的第 i 篇论文被引用的次数。计算并返回该研究者的 h 指数。
根据维基百科上 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

解题思路一:(排序后统计)

题目是寻找最大的 h,使得至少有 h 篇论文被引用 ≥h 次。

首先,对数组进行降序排序,即从大到小排序;

其次,从左向右遍历数组,如果 citations[i] > h 时,说明至少有 h+1篇文章引用次数 >= (h+1),因此可以安全的将 h自增1;

最后返回 h即为指数。

这种方法利用了排序后的特性:

当遍历到第 i 篇论文时,前面已经有 i 篇论文的引用次数 ≥ citations[i]。

如果 citations[i] > h 时,说明至少有 h+1篇文章引用次数 >= (h+1)。

可以这里理解上面的特性:

citations[i]: 当遍历到第i个元素值citations[i],表示前 i+1 篇论文的引用次数 ≥ citations[i](降序数组的特性)。
citations[i] > h ,因此:
前 i+1 篇论文的引用次数必然都 > h(因为它们 ≥ citations[i] > h)。
此时,至少有 i+1 篇论文的引用次数 > h,即:
至少有 i+1 篇论文的引用次数 ≥ h+1。

如果 i+1 ≥ h+1(即当前遍历到的论文数量足够),则说明:
存在 h+1 篇论文的引用次数 ≥ h+1,因此 H 指数可以更新为 h+1。

举例说明:

复制代码
举个例子:如果某人有 5 篇论文,引用次数是 [3, 0, 6, 1, 5],排序后为[6,5,3,1,0]
从前往后看:
    第 1 篇(6)≥ 1 → 至少有 1 篇 ≥ 1
    第 2 篇(5)≥ 2 → 至少有 2 篇 ≥ 2
    第 3 篇(3)≥ 3 → 至少有 3 篇 ≥ 3
    第 4 篇(1)< 4 → 不满足 4 篇 ≥ 4

具体方法如下:

  1. 首先初始化一个变量:h=0,来统计指数;

  2. 其次,从大到小进行排序;

  3. 从前往后遍历数组,判断 citations[i] > h,当满足时,h自增1。

4.循环退出,最后的 h即所求的指数;

C语言实现如下:

复制代码
//从大到小排序
int small_to_large(const void* a, const void* b) {
    return *(int*)b- *(int*)a;
}

int hIndex(int* citations, int citationsSize) {
    int i;
    int h = 0;
    qsort(citations, citationsSize, sizeof(int), small_to_large);

    for(i = 0; i < citationsSize; i++) {
        if(citations[i] > h) {
            h++;
        }
    }
    return h;
}

可以看出,排序解法的时间复杂度为 O (n log n)。

下一篇文章使用计数排序解法进行处理:

力扣网编程274题:H指数之计数排序(中等)-CSDN博客

相关推荐
2 分钟前
LeetCode Hot 100 括号生成
算法·leetcode·职场和发展
逝雪Yuki7 分钟前
Leetcode——42. 接雨水
c++·算法·leetcode·双指针·接雨水
香蕉可乐荷包蛋34 分钟前
排序算法 (Sorting Algorithms)-JS示例
javascript·算法·排序算法
练习时长两年半的程序员小胡1 小时前
JVM 垃圾回收机制全景解析:从对象回收到收集算法
java·jvm·算法·垃圾回收
姜不吃葱1 小时前
【力扣热题100】哈希——两数之和
算法·leetcode·哈希算法·力扣热题100
AI4Sci.1 小时前
在云服务器上基于lora微调Qwen2.5-VL-7b-Instruct模型(下)
人工智能·算法·机器学习·大模型·lora微调·大模型本地部署·qwen2.5-vl-7b
一只小风华~1 小时前
JavaScript:数组常用操作方法的总结表格
前端·javascript·数据结构·vue.js·算法
TiAmo zhang2 小时前
深度学习与图像处理 | 基于PaddlePaddle的梯度下降算法实现(线性回归投资预测)
图像处理·深度学习·算法
一匹电信狗2 小时前
【C++】手搓一个STL风格的vector容器
c语言·数据结构·c++·算法·leetcode·stl·visual studio
生信探索2 小时前
SeuratExtend 可视化教程(1):单细胞分析的高颜值绘图指南
算法