LeetCode每日一题: 至少是其他数字两倍的最大数(No.747)

栏目: 编程工具 · 发布时间: 5年前

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

示例:

输入: nums = [3, 6, 1, 0]
输出: 1
解释: 6是最大的整数, 对于数组中的其他整数,6大于数组中其他元素的两倍。6的索引是1, 所以我们返回1.

输入: nums = [1, 2, 3, 4]
输出: -1
解释: 4没有超过3的两倍大, 所以我们返回 -1.
复制代码

思考:

用一个变量max记录最大值索引,遍历数组。
如果当前数大于max数,再判断当前数有没有大于两倍的max数,用flag记录结果,并将当前数索引赋给max。
如果当前数小于max数,再判断max是否大于两给的当前述  同样用flag记录结果。
遍历结束,根据flag的真假来判断是否有找到合适的结果。
复制代码

实现:

class Solution {
public int dominantIndex(int[] nums) {
boolean flag = true;
int max = 0;
for(int i = 1; i < nums.length; i++){
    if(nums[i] > nums[max]){
	flag = nums[i] >= 2*nums[max] ? true : false;
	max = i;
    }else{
	flag = flag && nums[max] >= 2*nums[i] ? true : false;
    }
}
    return flag ? max : -1;
}
}复制代码

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

从问题到程序

从问题到程序

裘宗燕 / 机械工业出版社 / 2011-5 / 39.00元

《从问题到程序:程序设计与C语言引论(第2版)》以C作为工具语言,讨论了基本程序设计的各方面内容,详细解释了与c语言和程序设计有关的问题。在新版中,特别加强了针对近年日益受到业界和学术界广泛重视的问题的讨论,并通过详细地分析和讨论大量符合C99标准的实例,给出了分析和分解问题、找出解决问题的主要步骤、确定函数抽象、找出循环、选择语言结构直至最后做出所需程序的完整过程。 《从问题到程序:程序设......一起来看看 《从问题到程序》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具