博客
关于我
【Leetcode】275. H-Index II
阅读量:201 次
发布时间:2019-02-28

本文共 867 字,大约阅读时间需要 2 分钟。

题目地址:

题意是,给定一个单调增非负数组,找出满足这样性质的数 h h h:有多于等于 h h h个数是大于等于 h h h的。返回满足这样条件的最大的那个 h h h

思路是二分。首先考虑解的范围。显然 0 0 0是满足条件的,并且 h h h最大不超过数组长度 n n n,否则的话,要存在多于 n + 1 n+1 n+1个大于等于 n + 1 n+1 n+1的数,超出数组长度了,是不可能的。接下来 h h h有这样的性质:如果 h h h满足条件,那么 0 , . . . , h − 1 0,...,h-1 0,...,h1也满足条件。这为二分创造了条件。注意到 h h h满足条件,等价于数组倒数第 h h h个数是大于等于 h h h的,这就是判断条件。代码如下:

public class Solution {       public int hIndex(int[] citations) {           int l = 0, r = citations.length;        while (l < r) {               int m = l + (r - l + 1 >> 1);            // 判断倒数第m个数是不是大于等于m            if (citations[citations.length - m] >= m) {               	// 如果是,那么m满足条件,            	// 由于要找最大的满足条件的数,所以向右搜索                l = m;            } else {               	// 否则m不满足条件,需要向左搜索。                r = m - 1;            }        }                return l;    }}

时间复杂度 O ( log ⁡ n ) O(\log n) O(logn)

转载地址:http://flbs.baihongyu.com/

你可能感兴趣的文章
Navicat报错connection is being used
查看>>
Navicat报错:1045-Access denied for user root@localhost(using passwordYES)
查看>>
Navicat控制mysql用户权限
查看>>
navicat操作mysql中某一张表后, 读表时一直显示正在载入,卡死不动,无法操作
查看>>
Navicat连接mysql 2003 - Can't connect to MySQL server on ' '(10038)
查看>>
Navicat连接mysql数据库中出现的所有问题解决方案(全)
查看>>
Navicat连接Oracle出现Oracle library is not loaded的解决方法
查看>>
Navicat连接Oracle数据库以及Oracle library is not loaded的解决方法
查看>>
Navicat连接sqlserver提示:未发现数据源名并且未指定默认驱动程序
查看>>
navicat连接远程mysql数据库
查看>>
Navicat通过存储过程批量插入mysql数据
查看>>
Navicat(数据库可视化操作软件)安装、配置、测试
查看>>
navigationController
查看>>
NB-IOT使用LWM2M移动onenet基础通信套件对接之APN设置
查看>>
NBear简介与使用图解
查看>>
Vue过滤器_使用过滤器进行数据格式化操作---vue工作笔记0015
查看>>
Ncast盈可视 高清智能录播系统 IPSetup.php信息泄露+RCE漏洞复现(CVE-2024-0305)
查看>>
NCNN中的模型量化解决方案:源码阅读和原理解析
查看>>
NCNN源码学习(1):Mat详解
查看>>
nc命令详解
查看>>