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

LeetCode:274. H 指数、275. H 指数 II(C++)

目录

274. H 指数

题目描述:

实现代码与解析:

排序+暴力

275. H 指数 II

题目描述:

实现代码与解析:

二分


比较简单,不再写解析,注意二分的时候,r指针为n,含义为个数,而不是下标就行。

274. H 指数

题目描述:

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

根据维基百科上 h 指数的定义:h 代表“高引用次数” ,一名科研人员的 h 指数 是指他(她)至少发表了 h 篇论文,并且每篇论文 至少 被引用 h 次。如果 h 有多种可能的值,h 指数 是其中最大的那个。

示例 1:

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

示例 2:

输入:citations = [1,3,1]

实现代码与解析:

排序+暴力

class Solution {
public:int hIndex(vector<int>& citations) {sort(citations.begin(), citations.end(), [](int a, int  b) {return a > b;});int res = 0;for (int i = 0; i < citations.size(); i++) {if (citations[i] > i) {res = i + 1;} else {break;}}return res;}
};

275. H 指数 II

题目描述:

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

h 指数的定义:h 代表“高引用次数”(high citations),一名科研人员的 h 指数是指他(她)的 (n 篇论文中)总共有 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

实现代码与解析:

二分

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;if (citations[mid] >= n - mid) r = mid;else l = mid + 1;}return n - l;}
};
http://www.lryc.cn/news/213078.html

相关文章:

  • 多线程及锁
  • C++ 写一个Data类的注意问题
  • postman做接口测试
  • hdlbits系列verilog解答(always块)-29
  • uniapp实现瀑布流
  • 15. 机器学习 - 支持向量机
  • 如何根据进程号查询服务的端口号
  • 2.10、自定义量化优化过程
  • MySQL如何添加自定义函数
  • 超融合数据库:解锁全场景数据价值的钥匙
  • Pap.er for Mac:高清壁纸应用打造你的专属视觉盛宴
  • AI:46-基于深度学习的垃圾邮件识别
  • 【骑行贝丘渔场】一场与海的邂逅,一段难忘的旅程
  • 消息中间件——RabbitMQ(一)Windows/Linux环境搭建(完整版)
  • Mysql 表读锁与表写锁
  • 目标检测概述
  • 10月31日星期二今日早报简报微语报早读
  • 【Linux】虚拟机项目部署与发布
  • 边缘计算技术的崭新篇章:赋能未来智能系统
  • Mac/Linux类虚拟机_CrossOver虚拟机CrossOver 23.6正式发布2024全新功能解析
  • RabbitMQ 运维 扩展
  • [量化投资-学习笔记003]Python+TDengine从零开始搭建量化分析平台-Grafana画K线图
  • 前端接口请求支持内容缓存和过期时间
  • 【计算机网络】数据链路层——以太网
  • 【Spring】Spring MVC请求响应
  • 程序设计与算法(二)算法基础(北京大学MOOC)
  • 【MedusaSTears】正则表达式搜索心得
  • 带你从0开始学习自动化框架Airtest
  • MySQL扩展语句和约束方式
  • 用起来顺手的在线表结构设计软件工具Itbuilder,与你共享