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

设计制作生态瓶教学设计深圳防疫措施优化

设计制作生态瓶教学设计,深圳防疫措施优化,外贸公司没网站 怎么做业务,温州公司建设网站制作力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/h-index/description/?envTyped…

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/h-index/description/?envType=daily-question&envId=2023-10-29

给你一个整数数组 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]输出:1

h指数

例如h指数为3,则说明:

(1)至少发表了3篇论文——>符合条件(2)的元素个数≥3

(2)每篇论文至少被引用3次——>元素大小≥3

自己的思路

输入数组 citations,先将其排序,根据h指数的定义进行判断。

例如示例1

citations = [3,0,6,1,5]

排序后

citations = [0,1,3,5,6]

(1)≥0的元素有5个,记为<0,5>

(2)≥1的元素有4个,记为<1,4>

(3)≥2的元素有3个,记为<2,3>

(4)≥3的元素有3个,记为<3,3>

=====================(其实到这里就可以中止了,因为key<value,不符合h指数的定义)

(5)≥4的元素有2个,记为<4,2>

(6)≥5的元素有2个,记为<5,2>

(7)≥6的元素有1个,记为<6,1>

所以解题的重点是如何计算value,这里我使用了一层循环寻找比key大的元素个数。

代码

class Solution {public int find(int[] citations, int target) {int len = citations.length;for (int i = 0; i < len; i++) {if (citations[i] >= target) {return len - i;}}return 0;}public int hIndex(int[] citations) {Arrays.sort(citations);HashMap<Integer, Integer> hashMap = new HashMap<>();int len = citations.length;for (int i = 0; i < len + 1; i++) {int tmp = find(citations, i);if (i > tmp && hashMap.size() >= 1)break;hashMap.put(i, tmp);}System.out.println(hashMap);Object[] obj = hashMap.keySet().toArray();Arrays.sort(obj);return (int) obj[obj.length - 1];}
}

结果感觉不是很好

 

力扣官方题解

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。icon-default.png?t=N7T8https://leetcode.cn/problems/h-index/solutions/869042/h-zhi-shu-by-leetcode-solution-fnhl/?envType=daily-question&envId=2023-10-29只需要知道存在即可,例如排序后的示例1:

citations = [0,1,3,5,6]

假设h为0,从后往前比较,

首先是6>0,即为存在一篇论文,并且这一篇论文被引用次数>0,则可以将h设为1;

然后是5>1,即为存在两篇论文,并且这两篇论文被引用次数>1,则可以将h设为2(为什么是两篇?因为h还没有到达2,所以现在不可能出现引用次数<2的论文);

然后是3>2,即为存在三篇论文,并且这三篇论文被引用次数>2,则可以将h设为3;

最后是1<3,因为要取最大的,所以结束比较

代码

class Solution {public int hIndex(int[] citations) {Arrays.sort(citations);int h = 0, i = citations.length - 1; while (i >= 0 && citations[i] > h) {h++; i--;}return h;}
}

http://www.yidumall.com/news/87198.html

相关文章:

  • 网站制作九江游戏推广怎么做挣钱
  • 中国建设银行十堰分行网站seo关键词优化平台
  • 北京专业网站优化搜索引擎营销的基本方法
  • 香港服务器做网站seo人员是什么意思
  • flash网站动画一件代发48个货源网站
  • 网站建设高端培训竞价账户
  • 什么网站做英语翻译练习河南优化网站
  • 品牌网站建设十小蝌蚪网络推广公司口碑
  • 直播网站开发多少钱长春网站优化
  • wordpress菜单页面未找到关键词优化简易
  • ppt免费制作网站搜索关键词网站
  • 网站加搜索框海外营销公司
  • 平台网站可以做第三方检测报告品牌推广营销
  • 网站建设制作包括哪些怎么制作网站教程手机
  • 岐山网站开发58网络推广
  • 制作网页费用朔州网站seo
  • 一男一女做那个的动漫视频网站网络营销方案有哪些
  • 淘宝上 网站建设长春seo结算
  • 上海做网站品牌公司seo自学网官网
  • 陕西免费网站建设百度帐号管家
  • 网站页尾的作用app营销十大成功案例
  • 北京网页设计公司兴田德润优秀网站优化排名
  • 品牌网站建设權威大蝌蚪今日重要新闻
  • 哪个网站可以做专业兼职深圳网站设计公司哪家好
  • 广州天河网站开发公司北京网站制作公司
  • 网站开发 简单如何做营销策划方案
  • 做app布局参考哪个网站竞价排名的服务模式是
  • 中小企业网站制作多少钱自媒体怎么入门
  • java语言网站开发广东优化疫情防控措施
  • 呼伦贝尔建设网站北京网站优化方法