力扣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;
    }
}
相关推荐
用户938515635075 小时前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC6 小时前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥7 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者8 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者8 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月11 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星12 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星12 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试
To_OC1 天前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode