275. H 指数 II --力扣 --JAVA

题目

给你一个整数数组 citations ,其中 citations[i] 表示研究者的第 i 篇论文被引用的次数,citations 已经按照 升序排列 。计算并返回该研究者的 h 指数。

h 指数的定义:h 代表"高引用次数"(high citations),一名科研人员的 h 指数是指他(她)的 (n 篇论文中)总共有 h 篇论文分别被引用了至少 h 次。

请你设计并实现对数时间复杂度的算法解决此问题。

解题思路

  1. 数组是升序排列的,所以可以从后向前遍历;
  2. 遍历过的元素肯定大于等于当前元素的值,遍历过的元素数量为n - i;
  3. 只要当前元素的值大于等于遍历过的元素数量,既可作为结果之一;
  4. 选择最后结果最大值输出。

代码展示

java 复制代码
class Solution {
    public int hIndex(int[] citations) {
        int ans = 0;
        int n = citations.length;
        for (int i = n - 1; i >= 0; i--){
            if(citations[i] >=  n - i){
                ans = n - i;
            }
        }
        return ans;
    }
}
相关推荐
风筝在晴天搁浅19 小时前
剑指Offer 60.n个骰子的点数
算法
ProgramHelpOa19 小时前
Optiver 2026 OA 全面复盘|26NG / Intern 最新高频题型整理
人工智能·算法·机器学习
feifeigo12319 小时前
基于无迹变换的电网概率潮流分析 MATLAB 实现
开发语言·算法·matlab
Java成神之路-20 小时前
【算法刷题笔记】全题型导航目录
笔记·算法
爱写代码的倒霉蛋20 小时前
2022年天梯赛L1-8真题解析(哈希+排序)
数据结构·算法
代码中介商20 小时前
顺序表完全指南:从原理到实现
数据结构·顺序表
Struggle_975520 小时前
算法知识-倍增算法
算法
计算机安禾20 小时前
【计算机网络】第5篇:网桥学习与生成树算法——环路拓扑中的路径收敛问题
学习·计算机网络·算法
fie888920 小时前
基于遗传算法的机械故障诊断MATLAB程序
算法·机器学习·matlab
澈20720 小时前
C++ list容器完全指南
数据结构·c++·链表