壹 ❀ 引

刷leetcode的第二天,那么今天做的也是一道难度为简单的题目至少是其他数字的两倍的最大数,老规矩,先说说我的实现思路后,再来分析优质答案,原题如下:

在一个给定的数组nums中,总是存在一个最大元素 。

查找数组中的最大元素是否至少是数组中每个其他数字的两倍。

如果是,则返回最大元素的索引,否则返回-1。

示例 1:

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

输出: 1

解释: 6是最大的整数, 对于数组中的其他整数,

6大于数组中其他元素的两倍。6的索引是1, 所以我们返回1.

示例 2:

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

输出: -1

解释: 4没有超过3的两倍大, 所以我们返回 -1.

提示:

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

每个 nums[i] 的整数范围在 [0, 100].

那么本文开始。

贰 ❀ 听风是风不太聪明的实现

先说说我的实现,当然这段只是记录我在解题过程的思路,大家可以跳过直接看优质答案。

分析下题目,一个数组中如果最大的元素比其它元素都要大至少两倍,便返回最大元素的索引,如果有一个不满足则返回-1。

所以我想到先保存数组中最大元素的索引,然后从小到大排序,这样最大的元素在数组末尾,并分别与前面的元素做比较,直接贴代码:

/**
* @param {number[]} nums
* @return {number}
*/
var dominantIndex = function(nums) {
let len = nums.length,
result = 1;
// 如果数组只有一位,不用比较,直接返回索引0
if (len < 2) {
return 0;
};
// 记录最大值索引
var maxIndex = nums.indexOf(Math.max.apply(null, nums));
// 对数组进行排序
nums.sort((a, b) => a - b);
for (let i = 0; i < len - 1; i++) {
if (nums[len - 1] / nums[i] < 2) {
// 只要有一个不满足直接跳出循环
result = -1;
return result;
};
};
return maxIndex;
};

特别说明,题目要求的数组长度范围是[1,50],所以会存在数组只有一个元素的情况,我也是没仔细审题,所以第一次提交挂掉了,后面补了len < 2的情况。实现看起来很臃肿,我自己也这么觉得,来看看别人的思路。

叁 ❀ 优质解答

在我去看答案时瞟到了这样一句话,如果数组中最大的元素除2比第二大的元素还要大,这说明数组最大元素除2一定比所有元素都大!我顿时脑中闪过了一道闪电!

原来是这样!!!!这个思路直接秒杀我的实现,直接上代码:

/**
* @param {number[]} nums
* @return {number}
*/
var dominantIndex = function(nums) {
let len = nums.length;
// 如果数组只有一位,不用比较,直接返回索引0
if (len < 2) {
return 0;
};
// 记录最大值索引
let maxIndex = nums.indexOf(Math.max.apply(null, nums));
// 对数组进行排序
nums.sort((a, b) => a - b);
return nums[len - 1] / 2 >= nums[len - 2] ? maxIndex : -1;
};

这里还是做了排序,直接比较最后一位与倒数第二位,这个思路真的是太厉害了,像我这种脑瓜子就是没想上去...

最后还有个更厉害的实现,这里借用用户caoyq0521的实现代码:

/**
* @param {number[]} nums
* @return {number}
*/
var dominantIndex = function(nums) {
let max = Math.max(...nums);
let index = nums.indexOf(max);
nums = nums.filter(item => 2 * item > max);
return nums.length > 1 ? -1 : index;
};

比较惊奇没做排序,而是直接找出数组中最大元素与该元素的索引,之后对整个数组过滤,看看有没有元素乘2比最大元素还大,由于过滤过程中会遇到最大元素与自身毕竟的情况,所以最后三元的判断是nums.length > 1,毕竟最大元素乘2肯定会比自己大,这个思路也是极其巧妙,也是该题实现中耗时特别短的答案,超级佩服!

那么关于这道题就记录到这了,本文结束!

JS leetcode 至少是其他数字的两倍的最大数 解答思路分析的更多相关文章

  1. [LeetCode] Largest Number At Least Twice of Others 至少是其他数字两倍的最大数

    In a given integer array nums, there is always exactly one largest element. Find whether the largest ...

  2. LeetCode:至少是其他数字两倍的最大数【747】

    LeetCode:至少是其他数字两倍的最大数[747] 题目描述 在一个给定的数组nums中,总是存在一个最大元素 . 查找数组中的最大元素是否至少是数组中每个其他数字的两倍. 如果是,则返回最大元素 ...

  3. Java实现 LeetCode 747 至少是其他数字两倍的最大数(暴力)

    747. 至少是其他数字两倍的最大数 在一个给定的数组nums中,总是存在一个最大元素 . 查找数组中的最大元素是否至少是数组中每个其他数字的两倍. 如果是,则返回最大元素的索引,否则返回-1. 示例 ...

  4. [Swift]LeetCode747. 至少是其他数字两倍的最大数 | Largest Number At Least Twice of Others

    In a given integer array nums, there is always exactly one largest element. Find whether the largest ...

  5. Leetcode747至少是其他数字两倍的最大数

    Leetcode747至少是其他数字两倍的最大数 在一个给定的数组nums中,总是存在一个最大元素 .查找数组中的最大元素是否至少是数组中每个其他数字的两倍.如果是,则返回最大元素的索引,否则返回-1 ...

  6. [LC]747题 Largest Number At Least Twice of Others (至少是其他数字两倍的最大数)

    ①中文题目 在一个给定的数组nums中,总是存在一个最大元素 . 查找数组中的最大元素是否至少是数组中每个其他数字的两倍. 如果是,则返回最大元素的索引,否则返回-1. 示例 1: 输入: nums ...

  7. Leetcode747.Largest Number At Least Twice of Others至少是其他数字两倍的最大数

    在一个给定的数组nums中,总是存在一个最大元素 . 查找数组中的最大元素是否至少是数组中每个其他数字的两倍. 如果是,则返回最大元素的索引,否则返回-1. 示例 1: 输入: nums = [3, ...

  8. C#LeetCode刷题之#747-至少是其他数字两倍的最大数( Largest Number At Least Twice of Others)

    问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3746 访问. 在一个给定的数组nums中,总是存在一个最大元素 ...

  9. LeetCode747 至少是其他数字两倍的最大数

    在一个给定的数组nums中,总是存在一个最大元素 . 查找数组中的最大元素是否至少是数组中每个其他数字的两倍. 如果是,则返回最大元素的索引,否则返回-1. 示例 1: 输入: nums = [3, ...

  10. 转:JS判断值是否是数字(两种方法)

    JS判断值是否是数字   1.使用isNaN()函数 isNaN()的缺点就在于 null.空格以及空串会被按照0来处理 NaN: Not a Number /***判断是否是数字***/ 1 2 3 ...

随机推荐

  1. 两个List< string>比较是否相同的N种方法,你用过哪种?

    今天在一技术群看一群大佬讨论: 有没有优雅的写法,比较两个List集合中的元素是不是完全一致... 站长最近也无聊,通过群里的聊天记录和给出的参考链接,简单做做总结,万一后面大家能用上呢? 我们做简单 ...

  2. [js] - 导航展出动画

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. Android生成SHA1(证书指纹)

    去到jdk所在目录 C:\Program Files (x86)\Java\jdk1.8.0_73\bin 输入命令: keytool -list -v -keystore mykey.keystor ...

  4. [转帖]RAC AWR重要指标说明

    1.Global Cache Load Profile Global Cache blocks received:  接收到的全局缓冲块 Global Cache blocks served: 发送的 ...

  5. [转帖]Shell三剑客之awk

    目录 awk简述 awk的工作过程 awk的工作原理 awk的基本格式及其内置变量 getline 文本内容匹配过滤打印 对字段进行处理打印 条件判断打印 awk的三元表达式与精准筛选用法 awk的精 ...

  6. 关于decimal非常浅显的学习与整理

    关于decimal非常浅显的学习与整理 背景知识 整数,小数,浮点,定点 整数(Integer)是没有小数部分的数值,可以是正数.负数或零.在计算机中,整数通常以二进制形式存储. 小数(Decimal ...

  7. 多个物理磁盘挂载到同一目录的方法 (lvm 软raid)

    多个物理磁盘挂载到同一目录的方法 (lvm 软raid) 背景 公司里面的一台申威3231的机器 因为这个机器的raid卡没有操作界面. 所以只能够通过命令行方式创建raid 自己这一块比较菜, 想着 ...

  8. 【转帖】JVM的发展历程

    目录 1.Sun Classic VM 2.Exact VM 3.Sun HotSpot(主流) 4.JRockit 5.IBM J9 6.下一代虚拟机Graal VM 1.Sun Classic V ...

  9. [转帖]redis进程绑定指定的CPU核

    文章系转载,便于分类和归纳,源文地址:https://blog.csdn.net/youlinhuanyan/article/details/99671878 1)查看某服务的pid $ ps -au ...

  10. 跨主机Docker容器通信的学习

    背景 骨折在家找自己的人比较少. 又因为出不去也没法做运动,就不如将之前没学习深入的地方学习下 先是进行Docker 搭建 redis cluster的处理. 当时发现必须使用 --net=host进 ...