747. 至少是其他数字两倍的最大数
admin
2024-05-21 05:37:55

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

难度简单187收藏分享切换为英文接收动态反馈

给你一个整数数组 nums ,其中总是存在 唯一的 一个最大整数 。

请你找出数组中的最大元素并检查它是否 至少是数组中每个其他数字的两倍 。如果是,则返回 最大元素的下标 ,否则返回 -1 。

示例 1:

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

输出:1

解释:6 是最大的整数,对于数组中的其他整数,6 至少是数组中其他元素的两倍。6 的下标是 1 ,所以返回 1 。

示例 2:

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

输出:-1

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

示例 3:

输入:nums = [1]

输出:0

解释:因为不存在其他数字,所以认为现有数字 1 至少是其他数字的两倍。

提示:

  • 1 <= nums.length <= 50

  • 0 <= nums[i] <= 100

  • nums 中的最大元素是唯一的

int dominantIndex(int* nums, int numsSize){if(numsSize == 1)//只有一个数时 返回0{return 0;}//因为要返回下标 所以原来数组的位置不能被改变 也可以根据提示将数组开到最大int *num = (int*)malloc(sizeof(int)*numsSize);for(int i = 0;i

官方题解

int dominantIndex(int* nums, int numsSize) {int m1 = -1, m2 = -1;int index = -1;for (int i = 0; i < numsSize; i++) {if (nums[i] > m1) {m2 = m1;m1 = nums[i];index = i;} else if (nums[i] > m2) {m2 = nums[i];}}return m1 >= m2 * 2 ? index : -1;
}

来源于leetcode

上一篇:CentOS7 安装 Docker

下一篇:linux安装docker

相关内容

热门资讯

北京八达岭长城门票预约攻略 一、八达岭长城门票官方预约平台全知晓 二、八达岭长城门票其他预约途径大揭秘 三、八达岭长城门票预约注...
泡人参酒别瞎选!用这种酒,营养... 作为一个对泡酒颇有研究的老炮儿,这些年我尝试了各种泡酒配方,要说最经典的,还得是人参泡酒。身边不少中...
南京一蛋糕店标明详细成本引热议... 南京一蛋糕店标明详细成本引热议,店家:让大家吃得放心南京一蛋糕店标明详细成本
分享茄子常见的3种家常做法,解... 茄子是餐桌上常见的"平民食材",其绵软吸味的特性让它成为家常菜中的百搭选手。今天分享三款茄子经典做法...
原创 炸... 各位炸鸡爱好者们,今天我要揭穿一个炸鸡界最大的谎言—— 裹粉根本不是第一步!上周我用新方法炸的鸡翅,...