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

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

在一个给定的数组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;
}
}复制代码

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

查看所有标签

猜你喜欢:

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

30天自制操作系统

30天自制操作系统

[日] 川合秀实 / 周自恒、李黎明、曾祥江、张文旭 / 人民邮电出版社 / 2012-8 / 99.00元

自己编写一个操作系统,是许多程序员的梦想。也许有人曾经挑战过,但因为太难而放弃了。其实你错了,你的失败并不是因为编写操作系统太难,而是因为没有人告诉你那其实是一件很简单的事。那么,你想不想再挑战一次呢? 这是一本兼具趣味性、实用性与学习性的书籍。作者从计算机的构造、汇编语言、C语言开始解说,让你在实践中掌握算法。在这本书的指导下,从零编写所有代码,30天后就可以制作出一个具有窗口系统的32位......一起来看看 《30天自制操作系统》 这本书的介绍吧!

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

Base64 编码/解码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具