力扣H指数——简约做法

Problem: 274. H 指数

文章目录

思路

最后的结果一定不会超过下标个数。应为文章也要大于这个h,h超过了文章总数,就永远不会存在这么多的文章满足条件,所以只需要循环下标,那么最后的结果呢?

解题方法

由于排了序,所以后面的文章引用数量一定大于等于目前的数量,能不能以文章的引用为判断呢,不能,设想6 6 6 6 6 6 6 6 6 ,如果以引用方式,我们发现我们只能判断6,但是很明显中间的6可以满足条件,因为不同的文章数量也会影响结果,所以这种思路是错的。所以目标就是,如果目前位置开始所有的文章数量比引用数量来的要小,那么就满足条件。

复杂度

时间复杂度:

O ( n l o g n ) O(nlogn) O(nlogn)

空间复杂度:

O ( n l o g n ) O(nlogn) O(nlogn)

Code

Java 复制代码
class Solution {
    public int hIndex(int[] citations) {
        Arrays.sort(citations);
        int ans=0;
        for(int i = 0;i <= citations.length-1; i++){
            if(citations.length-i<=citations[i]){
                ans = Math.max(ans,citations.length-i);
            }
        }
        return ans;
    }
}
相关推荐
GISer_Jing6 分钟前
Javascript排序算法(冒泡排序、快速排序、选择排序、堆排序、插入排序、希尔排序)详解
javascript·算法·排序算法
cookies_s_s7 分钟前
Linux--进程(进程虚拟地址空间、页表、进程控制、实现简易shell)
linux·运维·服务器·数据结构·c++·算法·哈希算法
不想编程小谭43 分钟前
力扣LeetCode: 2506 统计相似字符串对的数目
c++·算法·leetcode
水蓝烟雨1 小时前
[HOT 100] 2187. 完成旅途的最少时间
算法·hot 100
01_2 小时前
力扣hot100——LRU缓存(面试高频考题)
leetcode·缓存·面试·lru
菜鸟一枚在这2 小时前
深度解析建造者模式:复杂对象构建的优雅之道
java·开发语言·算法
gyeolhada2 小时前
2025蓝桥杯JAVA编程题练习Day5
java·数据结构·算法·蓝桥杯
阿巴~阿巴~2 小时前
多源 BFS 算法详解:从原理到实现,高效解决多源最短路问题
开发语言·数据结构·c++·算法·宽度优先
给bug两拳3 小时前
Day9 25/2/22 SAT
算法
_Itachi__3 小时前
LeetCode 热题 100 73. 矩阵置零
算法·leetcode·矩阵