这是悦乐书的第308次更新,第328篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第177题(顺位题号是747)。在给定的整数数组中,总有一个最大的元素。查找数组中的最大元素是否至少是数组中每个其他数字的两倍。如果是,则返回最大元素的索引,否则返回-1。例如:

输入:nums = [3,6,1,0]

输出:1

说明:6是最大的整数,对于数组x中的每个其他数字,6是x的两倍多。 值6的索引是1,所以我们返回1。

输入:nums = [1,2,3,4]

输出:-1

说明:4至少不是3的值的两倍,所以我们返回-1。

注意:

nums的长度在[1,50]范围内。

每个nums [i]将是[0,99]范围内的整数。

本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 第一种解法

题目的要求是返回最大数的索引,所以需要先将最大数找出来,并记录下其索引。然后在次遍历数组中的元素,将最大数之外的其他数都乘以2和最大数比较(在此处我是使用位移处理),如果大于就返回-1,如果其他元素都满足条件,就返回之前记录的最大数的索引。

public int dominantIndex(int[] nums) {

int index = 0, max = 0;

for (int i=0; i

if (nums[i] > max) {

max = nums[i];

index = i;

}

}

for (int i=0; i

if (nums[i] != max && nums[i]<<1 > max) {

return -1;

}

}

return index;

}

03 第二种解法

我们还可以只使用一次循环来解决。并非需要使用每一个元素乘以2后再去和最大元素比较,只需要用第二大的数去比较就行,如果第二大的数不能满足条件,就可以直接做判断了。比如[2,3,4],3乘以2等于6大于4,不符合题目要求,就不需要比较2了。

public int dominantIndex(int[] nums) {

int max = 0, second = 0, index = 0;

for (int i=0; i

if (nums[i] > max) {

second = max;

max = nums[i];

index = i;

} else if(nums[i] > second) {

second = nums[i];

}

}

return second<<1 <= max ? index : -1;

}

04 小结

算法专题目前已日更超过五个月,算法题文章177+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

largest number java_LeetCode算法题-Largest Number At Least Twice of Others(Java实现)相关推荐

  1. java perfect number_LeetCode算法题-Perfect Number(Java实现)

    这是悦乐书的第249次更新,第262篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第116题(顺位题号是507).我们定义Perfect Number是一个正整数,它等于 ...

  2. leetcode 用java_LeetCode算法题-Heaters(Java实现)

    这是悦乐书的第239次更新,第252篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第106题(顺位题号是475).冬天来了!您在比赛期间的第一份工作是设计一个固定温暖半径 ...

  3. add binary java_LeetCode算法题-Add Binary(Java实现)

    这是悦乐书的第157次更新,第159篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第16题(顺位题号是67).给定两个二进制字符串,返回它们的总和(也是二进制字符串).输 ...

  4. power of two java_LeetCode算法题-Power Of Two(Java实现)

    这是悦乐书的第194次更新,第200篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第56题(顺位题号是231).给定一个整数,写一个函数来确定它是否是2的幂.例如: 输入 ...

  5. min java_LeetCode算法题-Min Stack(Java实现)

    这是悦乐书的第177次更新,第179篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第36题(顺位题号是155).设计一个支持push,pop,top和在恒定时间内检索最小 ...

  6. magic square java_LeetCode算法题-Magic Squares In Grid(Java实现)

    这是悦乐书的第326次更新,第349篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第196题(顺位题号是840).3 x 3魔方是一个3 x 3网格,填充了从1到9的不同 ...

  7. quadtree java_LeetCode算法题-Construct Quad Tree(Java实现)

    这是悦乐书的第224次更新,第237篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第91题(顺位题号是427).我们想使用四叉树来存储N×N布尔网格.网格中的每个单元格只 ...

  8. island of java_LeetCode算法题-Island Perimeter(Java实现)

    这是悦乐书的第238次更新,第251篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第105题(顺位题号是463).您将获得一个二维整数网格形式的地图,其中1代表土地,0代 ...

  9. quadtree java_LeetCode算法题-Quad Tree Intersection(Java实现)

    这是悦乐书的第260次更新,第273篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第127题(顺位题号是558).四叉树是树数据,其中每个内部节点恰好有四个子节点:top ...

最新文章

  1. AMD Ryzen 5000‘Cezanne’APU
  2. 姚班学霸陈立杰:16岁保送清华,18岁拿下IOI世界冠军,现摘得FOCS 2019最佳学生论文...
  3. 免除重装系统的烦恼,为SSD做系统移植,并从光驱位SSD启动系统
  4. 深入解读ESB与SOA的关系
  5. Kotlin - 100%兼容java和android开发
  6. RabbitMQ学习之集群模式
  7. 喜马拉雅音频转mp3方法
  8. 简单地图的实现Android,android开发一:高德地图的简单制作
  9. 集成电路设计的运作模式
  10. 这可能是史上最全的常用学术网站
  11. 20175212童皓桢 实验五 网络编程与安全
  12. 微信朋友圈卖葡萄经验分享
  13. 社区产品如何搭建内容体系?看看懂球帝与虎扑如何做
  14. 【以太网硬件二】802.3标准里有哪些内容?
  15. 毕业设计 stm32便携用电功率统计系统 -物联网 嵌入式 单片机
  16. Git必学的merge和rebase区别
  17. Python学习之路(一)
  18. W25QXX芯片使用
  19. 小型太阳能电站有望进入家庭
  20. 必须背单词、学语法?不,说一口地道的英语可以更容易!

热门文章

  1. php js混淆加密工具,求混淆js加密算法解密
  2. MMD_2a_FindSimilarSets
  3. 全长转录组之基因和转录本鉴定
  4. An improved genome reference for the African cichlid, Metriaclima zebra 非洲慈鲷,斑马宫丽鱼的改良基因组参考
  5. debian php 升级,Debian和ubuntu服务器升级PHP7
  6. 微服务配置中心是干啥的_配置中心微服务器配置
  7. bash: dotnet: 未找到命令..._Docker 常用命令(.NET Core示例)
  8. python字典按value逆序排序_python 对字典按照value进行排序的方法
  9. tensorflow tf.keras.utils.plot_model 画深度学习神经网络拓扑图
  10. pandas UnicodeDecodeError: ‘utf-8‘ codec can‘t decode byte 0xb1 in position 0: invalid start byte