这篇文章主要介绍“PHP 如何计算至少是其他数字两倍的最大数”,在日常操作中,相信很多人在PHP 如何计算至少是其他数字两倍的最大数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP 如何计算至少是其他数字两倍的最大数”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
计算至少是其他数字两倍的最大数
在一个给定的数组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]
.
来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/largest-number-at-least-twice-of-others
解题思路
循环一遍,记录最大值,次大值,最后判断如果最大值大于次大值 * 2,则返回最大值的 index,否则返回 -1
PHP 实现
class Solution {
/**
* @param Integer $num
* @return Boolean
*/
function dominantIndex($nums) {
$count = count($nums);
if ($count === 1) return 0;
$max = 0;
$subMax = 0;
$index = 0;
for($i = 0; $i < $count; $i++) {
if($nums[$i] >= $max){
$subMax = $max;
$max = $nums[$i];
$index = $i;
} else if ($nums[$i] > $subMax) {
$subMax = $nums[$i];
}
}
return ($max >= $subMax * 2) ? $index : -1;
}
}
总结
到此,关于“PHP 如何计算至少是其他数字两倍的最大数”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
网络异常,请检查网络