当前位置: 首页 > news >正文

Leetcode.275 H 指数 II

题目链接

Leetcode.275 H 指数 II mid

题目描述

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

h h h 指数的定义: h h h 代表“高引用次数”( h i g h c i t a t i o n s high citations highcitations),一名科研人员的 h h h 指数是指他(她)的 ( n n n 篇论文中)总共有 h h h 篇论文分别被引用了至少 h h h 次。

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

示例 1:

输入:citations = [0,1,3,5,6]
输出:3
解释:给定数组表示研究者总共有 5 篇论文,每篇论文相应的被引用了 0, 1, 3, 5, 6 次。
由于研究者有3篇论文每篇 至少 被引用了 3 次,其余两篇论文每篇被引用 不多于 3 次,所以她的 h 指数是 3 。

示例 2:

输入:citations = [1,2,100]
输出:2

提示:
  • n = c i t a t i o n s . l e n g t h n = citations.length n=citations.length
  • 1 ≤ n ≤ 1 0 5 1 \leq n \leq 10^5 1n105
  • 0 ≤ c i t a t i o n s [ i ] ≤ 1000 0 \leq citations[i] \leq 1000 0citations[i]1000
  • c i t a t i o n s citations citations升序排列

解法:二分

初始 l = 0 , r = n l = 0 , r = n l=0,r=n

我们可以得到 m i d mid mid ,如果 c i t a t i o n s citations citations 中 大于等于 m i d mid mid 的元素一共有 c n t cnt cnt 个。

  • 如果 c n t ≥ m i d cnt \geq mid cntmid,说明 c n t cnt cnt 指数,是满足 c i t a t i o n s citations citations 的,故 l = m i d l = mid l=mid
  • 如果 c n t ≥ m i d cnt \geq mid cntmid,说明 c n t cnt cnt 指数,不满足 c i t a t i o n s citations citations 的,故 r = m i d − 1 r = mid - 1 r=mid1

时间复杂度: O ( l o g 2 n ) O(log^2n) O(log2n)

C++代码:

class Solution {
public:int hIndex(vector<int>& citations) {int n = citations.size();int l = 0  , r = n;while(l < r){int mid = (l + r + 1) >> 1;auto it = lower_bound(citations.begin(),citations.end(),mid);int cnt = citations.end() - it;if(cnt >= mid) l = mid;else r = mid - 1;}return l;}
};
http://www.lryc.cn/news/212028.html

相关文章:

  • 代码随想录Day40-单调栈:力扣第496e、503m、42h、84h题
  • Git窗口打开vim后如何退出编辑(IDEA/Goland等编辑器)
  • 【CSDN 每日一练 ★★☆】【二叉树/BSF】二叉树的层序遍历
  • Golang | Zinx学习笔记(一)
  • 【Java 进阶篇】在Java Web应用中获取ServletContext对象详解
  • 负债6W,依靠这个项目副业6个月还清欠款,还多存了10W+
  • 快速了解ClickHouse!
  • PythonWEB
  • 【工具问题】IDEA每次关闭的时候都会弹框显示closing project,然后弹框持续很久就像卡住了
  • 从瀑布模式到水母模式:ChatGPT如何赋能软件研发全流程
  • 类变量/方法、main语法、代码块
  • [SHCTF 校外赛道] crypto
  • vue3从基础到入门(一)
  • 枚举类型 表示不同的 HTTP 状态码和相应的错误消息
  • SAP 使用cl_gui_timer自动刷新屏幕的用法详解 <转载>
  • golang中的Interface接口 类型断言、接口赋值、空接口的使用、接口嵌套
  • 使用设计模式省去大量的if-elsef分支
  • Tomcat安装与配置文件解读
  • 计算机网络重点概念整理-第一章 计算机网络概述【期末复习|考研复习】
  • Day 11 python学习笔记
  • HarmonyOS鸿蒙原生应用开发设计- 图标库
  • 微软bing大声朗读文档或网页卡顿老是中断,用离线的huihui就很流畅但没那么自然
  • Java VMTranslator Part I
  • ES6带来那些js新特性?
  • js数组深拷贝汇总
  • 错误 LNK1112 模块计算机类型“x64”与目标计算机类型“X86”冲突
  • java八股文(基础篇)
  • window系统修改rabbitmq 默认端口
  • 七人拼团模式:颠覆你的购物观念,499元产品让你赚翻天!
  • 【机器学习合集】模型设计之卷积核设计 ->(个人学习记录笔记)