【java】力扣 H指数

文章目录

题目链接

274.H指数

题目描述

思路

设置n为citations的长度,也就是发表论文的篇数,h肯定是不能超过n的,所以当有引用次数大于n时,我们要看成n,

要创建一个数组arr,来存储引用次数的篇数,统计min(citations[i],n)出先得次数,比如引用次数是 5次的有两个,引用次数是3次的有一个

s为引用次数>=h的文章数,h=n,采用倒数的循坏,每次循环,把arr[i]加到s种,只要s>=h成立,返回的i就是所求的h指数

代码

java 复制代码
public int hIndex(int[] citations) {
        int n = citations.length;
        int[] arr = new int[n+1];
        for(int c:citations){
            arr[Math.min(c,n)]++;
        }
        int s=0;
        for(int h =n;;h--){
            s +=arr[h];
            if(s>=h){
                return h;
            }
        }
    }
相关推荐
自我意识的多元宇宙7 分钟前
树、森林——树、森林与二叉树的转换(森林转换为二叉树)
数据结构
敖正炀9 分钟前
PriorityBlockingQueue 详解
java
shark222222215 分钟前
Spring 的三种注入方式?
java·数据库·spring
海清河晏11116 分钟前
数据结构 | 双循环链表
数据结构·链表
陈煜的博客28 分钟前
idea 项目只编译不打包,跳过测试,快速开发
java·ide·intellij-idea
py有趣29 分钟前
力扣热门100题之编辑距离
数据结构·算法·leetcode
JAVA学习通32 分钟前
LangChain4j 与 Spring AI 的技术选型深度对比:2026 年 Java AI 工程化实践指南
java·人工智能·spring
.柒宇.1 小时前
Java八股之反射
java·开发语言
敖正炀1 小时前
LinkedTransferQueue 详解
java
环流_1 小时前
多线程1(面试题--常见的线程创建方式)
java·开发语言·面试