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

news/2025/1/11 13:21:50/

问题描述

给定一个整数数组 nums,其中总是存在唯一的一个最大整数。任务是找出数组中的最大元素,并检查它是否至少是数组中每个其他数字的两倍。如果是,则返回最大元素的下标;否则,返回 -1

解题思路

这个问题可以通过两个主要步骤解决:

  1. 寻找最大元素及其下标:首先,我们需要遍历数组以找到最大元素及其下标。

  2. 验证条件:然后,我们需要检查这个最大元素是否至少是数组中其他每个元素的两倍。

 

算法实现

以下是使用 C++ 语言实现的算法

#include <vector>public:int dominantIndex(std::vector<int>& nums) {int maxIndex = 0;int n = nums.size();// Step 1: Find the maximum element and its indexfor (int i = 1; i < n; i++) {if (nums[i] > nums[maxIndex]) {maxIndex = i;}}// Step 2: Check if the maximum element is at least twice of any other elementfor (int i = 0; i < n; i++) {if (i != maxIndex && nums[maxIndex] < nums[i] * 2) {return -1; // Condition not met}}return maxIndex; // Condition met, return the index of the maximum element}
};

代码分析

  • 时间复杂度:O(n),其中 n 是数组 nums 的长度。这是因为我们遍历数组两次:一次寻找最大元素,一次验证条件。

  • 空间复杂度:O(1),我们只使用了有限的额外空间。

结论

这个问题是一个典型的数组问题,它要求我们首先找到数组中的最大元素,然后进行条件验证。通过这个例子,我们可以看到,有时候解决问题的关键在于正确地分解问题并逐步解决每个子问题。

 


http://www.ppmy.cn/news/1561868.html

相关文章

Docker + JMeter + InfluxDB + Grafana搭建压测可视化实时监控

一:简单介绍 为了解决上述问题,必须要请出了 InfluxDB + Grafana : InfluxDB :持续型数据库,有时间戳组件,以时间的形式去存储数据; Grafana :一款采用 Go 语言编写的开源应用,主要用于大规模指标数据的可视化展现,是网络架构和应用分析中最流行的时序数据展示工具…

【大模型】百度千帆大模型对接LangChain使用详解

目录 一、前言 二、LangChain架构与核心组件 2.1 LangChain 核心架构 2.2 LangChain 核心组件 三、环境准备 3.1 前置准备 3.1.1 创建应用并获取apikey 3.1.2 开通付费功能 3.2 获取LangChain文档 3.3 安装LangChain依赖包 四、百度千帆大模型对接 LangChain 4.1 LL…

Pytorch机器学习——1 深度学习介绍

outline 人工智能、机器学习与深度学习深度学习工具介绍 1. 人工智能、机器学习与深度学习 AI&#xff1a;研究如何能让计算机模拟人类的智能&#xff0c;来实现特定的依赖人类智能才能实现的任务&#xff08;例如学习、语言、识别&#xff09; AI历史&#xff1a; 1818&#x…

Calico BGP网络问题

Calico BGP网络问题 文章目录 Calico BGP网络问题排除步骤calico-node 正常运行&#xff0c;但在 describe 中有警告信息错误现象 ip route 路由表中删除 blackhole后又会自动生成网卡选择无效导致 calico 的 pod 内容器未就绪问题现象原因分析问题解决方式一&#xff1a;直接修…

selenium已经登陆了 我怎么查看 网页 在fRequest xhr 的数据呢

在使用 Selenium 登录网页后&#xff0c;查看网页的 XHR 请求数据可以通过以下几种方法&#xff1a; ### 1. 使用浏览器开发者工具 - **手动查看**&#xff1a; - 打开浏览器的开发者工具&#xff08;按 F12 或右键点击页面元素选择“检查”&#xff09;。 - 切换到“Netw…

c++ 输入输出

<iostream>是 Input Output Stream 的缩写&#xff0c;是标准的输入、输出流库&#xff0c;定义了标准的输入、输出 对象。 std::cin 是istream 类的对象&#xff0c;它主要面向窄字符(narrow characters(oftype char))的标准输入流。 std::cout 是 ostream 类的对象&…

【HF设计模式】05-单例模式

声明&#xff1a;仅为个人学习总结&#xff0c;还请批判性查看&#xff0c;如有不同观点&#xff0c;欢迎交流。 摘要 《Head First设计模式》第5章笔记&#xff1a;结合示例应用和代码&#xff0c;介绍单例模式&#xff0c;包括遇到的问题、采用的解决方案、以及达到的效果。…

docker中使用Volume完成数据共享

情景概述 在一个docker中&#xff0c;部署两个MySQL容器&#xff0c;假如它们的数据都存储在自己容器内部的data目录中。这样的存储方式会有以下问题&#xff1a; 1.无法保证两个MySQL容器中的数据同步。 2.容器删除后&#xff0c;数据就会丢失。 基于以上问题&#xff0c;容…