当前位置: 首页 > article >正文

每日算法练习:LeetCode 169. 多数元素 ✅

大家好我是你们的算法小伙伴。今天我们来练习一道经典的数组问题 ——LeetCode 169. 多数元素它的最优解法「摩尔投票法」非常巧妙是面试中的高频考点。题目描述给定一个大小为n的数组nums返回其中的多数元素。多数元素是指在数组中出现次数大于⌊ n/2 ⌋的元素。你可以假设数组是非空的并且给定的数组总是存在多数元素。示例 1输入nums [3,2,3] 输出3示例 2输入nums [2,2,1,1,1,2,2] 输出2提示n nums.length1 n 5 * 10^4-10^9 nums[i] 10^9输入保证数组中一定有一个多数元素进阶尝试设计时间复杂度为 O (n)、空间复杂度为 O (1) 的算法解决此问题。解题思路方法一哈希表统计直观但空间复杂度高遍历数组用哈希表记录每个元素的出现次数最后遍历哈希表找到出现次数大于 n/2 的元素。时间复杂度O (n)空间复杂度O (n)方法二排序取中间元素利用多数元素特性因为多数元素出现次数大于 n/2所以排序后数组中间位置的元素一定是多数元素。时间复杂度O (n log n)空间复杂度O (1)若使用原地排序方法三摩尔投票法最优解这是题目进阶要求的 O (n) 时间、O (1) 空间解法核心思想是抵消不同元素也是我们重点要讲解的方法。核心前提题目明确保证数组中一定存在多数元素且出现次数 n/2。这意味着多数元素的数量 所有其他元素的数量之和这是摩尔投票法能生效的根本 —— 它的 “票数” 永远无法被完全抵消。通俗类比理解我们可以把这个过程想象成一场 “候选人对抗赛”数组里的每个元素都是一个 “候选人”互相 “投票对抗”多数元素的支持者足够多哪怕和所有其他候选人对抗最后剩下的也一定是它count就是当前候选者的净胜票数遇到和自己一样的元素 → 净胜票 1支持者增加遇到不一样的元素 → 净胜票 - 1互相抵消净胜票为 0 时 → 说明当前候选者的票数被完全抵消换当前元素当新候选。算法步骤初始化选数组第一个元素为初始候选candidate计数器count 1从第二个元素开始遍历数组若当前元素等于candidate→count若当前元素不等于candidate→count--若count 0→ 更新candidate为当前元素重置count 1遍历结束后candidate就是多数元素。代码实现class Solution { public int majorityElement(int[] nums) { // 1. 初始化选第一个元素当初始候选初始净胜票为 1 int candidate nums[0]; int count 1; // 2. 从第二个元素开始遍历第一个已作为候选 for (int i 1; i nums.length; i) { if (nums[i] candidate) { // 情况1遇到和候选相同的元素 → 净胜票1 count; } else { // 情况2遇到不同元素 → 净胜票-1互相抵消 count--; // 情况3净胜票为 0 → 候选者被完全抵消换当前元素当新候选 if (count 0) { candidate nums[i]; count 1; } } } // 3. 遍历结束剩下的候选就是多数元素 return candidate; } }代码逐行拆解初始化candidate nums[0]先假设第一个元素是候选count 1表示它有 1 票领先遍历逻辑相同元素增强当前候选的领先优势不同元素消耗当前候选的票数实现 “抵消”票数清零说明当前候选的优势耗尽更换新候选重新开始计数结果保证因为多数元素数量 其他元素总和所以它永远无法被完全抵消最终一定会成为最后剩下的候选。实例模拟验证我们以nums [2,2,1,1,1,2,2]多数元素是 2出现 4 次n743.5为例全程模拟执行过程表格遍历位置 (i)当前元素candidate (候选)count (净胜票)执行逻辑初始化-21选第一个元素 2 当候选初始票 1i1222和候选相同净胜票 1i2121和候选不同净胜票 - 1抵消 1 票i3120和候选不同净胜票 - 1 → 变为 0i4111count0 → 换候选为 1重置票 1i5210和候选不同净胜票 - 1 → 变为 0i6221count0 → 换候选为 2重置票 1遍历结束-21返回候选 2正确结果复杂度分析时间复杂度O (n)。仅需遍历数组一次执行 n-1 次操作。空间复杂度O (1)。仅使用两个变量存储候选和计数器无额外空间开销。总结这道题的核心魅力在于摩尔投票法它完美利用了「多数元素出现次数超过一半」的特性在不借助额外空间的情况下通过简单的计数与抵消操作高效找到结果。这种思想在处理「寻找出现次数超过 1/k 的元素」等进阶问题时也有重要应用是算法面试中必须掌握的经典技巧。今天的每日算法练习就到这里我们明天再见

相关文章:

每日算法练习:LeetCode 169. 多数元素 ✅

大家好,我是你们的算法小伙伴。今天我们来练习一道经典的数组问题 ——LeetCode 169. 多数元素,它的最优解法「摩尔投票法」非常巧妙,是面试中的高频考点。题目描述给定一个大小为 n 的数组 nums,返回其中的多数元素。多数元素是指…...

下载亚马逊Corretto 17的方法(OpenJDK 17发行版)

Corretto 17的定义 Corretto 17是亚马逊(Amazon)提供的免费、多平台、生产就绪的OpenJDK 17发行版。作为OpenJDK的下游版本,它完全兼容Java SE标准,并提供长期支持(LTS),适用于企业级应用开发和…...

ACS X轴回零程序 项目实战版

代码INT iAxis REAL HomeVel REAL SearchLimitVel REAL HomeOffset REAL timeoutiAxis 0 HomeVel 5 SearchLimitVel 10 HomeOffset 157 timeout 50000VEL(iAxis) SearchLimitVel ACC(iAxis) VEL(iAxis) * 10 DEC(iAxis) VEL(iAxis) * 10 JERK(iAxis) VEL(iAxis) * 100…...

从零开始:构建具有幻觉缓解能力的AI原生应用

从零开始:构建具有幻觉缓解能力的AI原生应用 关键词:AI原生应用、幻觉缓解、从零开始构建、人工智能、应用开发 摘要:本文将带领大家从零开始构建具有幻觉缓解能力的AI原生应用。我们会先介绍相关背景知识,解释核心概念,接着阐述核心算法原理和具体操作步骤,通过数学模型…...

C++ 标准库提供了一组丰富的输入/输出功能

C 基本的输入输出 C 标准库提供了一组丰富的输入/输出功能,我们将在后续的章节进行介绍。本章将讨论 C 编程中最基本和最常见的 I/O 操作。 C 的 I/O 发生在流中,流是字节序列。如果字节流是从设备(如键盘、磁盘驱动器、网络连接等&#xff0…...

通常,当我们需要用到数字时,我们会使用原始的数据类型

C 数字 通常&#xff0c;当我们需要用到数字时&#xff0c;我们会使用原始的数据类型&#xff0c;如 int、short、long、float 和 double 等等。这些用于数字的数据类型&#xff0c;其可能的值和数值范围&#xff0c;我们已经在 C 数据类型一章中讨论过。 #include <iostrea…...

C++ 是一种静态类型的、编译式的、通用的、大小写敏感的、不规则的编程语言

要判断这个关于C的描述是否准确&#xff0c;我们可以从以下几个方面来分析&#xff1a; 1. 静态类型 静态类型语言要求在编译时确定变量的类型&#xff0c;且类型在程序运行过程中一般不会改变。C属于静态类型语言&#xff0c;和C、Java等类似&#xff0c;在声明变量时必须指定…...

OSVR - Open-Source Virtual Reality - 开源虚拟现实

OSVR - Open-Source Virtual Reality - 开源虚拟现实1. OSVR Organization2. OSVR Developer PortalReferenceshttp://www.osvr.org/ http://www.osvr.org/cn-zh/ 虚拟现实是一种重现实际或虚构环境&#xff0c;模拟用户在其中真实存在的沉浸式数字娱乐形式。这种体验还模拟感…...

Visual Studio 2015 - 格式化代码

Visual Studio 2015 - 格式化代码1. 格式化代码References1. 格式化代码 Ctrl K, Ctrl D - 格式化文档 Ctrl K, Ctrl F - 格式化选择 References [1] Yongqiang Cheng (程永强), https://yongqiang.blog.csdn.net/...

Altium生成Gerber及CAM350、DFM检查

完成 PCB 板图的设计并交给供应商进行打样或是量产时&#xff0c;一般不会直接给供应商 PCB 源文件&#xff0c;那就需要生成 Gerber文件。那么如何生成 Gerber文件及用 CAN350软件或华秋DFM 进行检查。 目录&#xff1a; 一、Gerber文件清单 二、Gerber各文件讲解 三、生成…...

SpringCloud动态路由利器--router4j

前言 本文介绍Java的动态路由中间件&#xff1a;router4j。router4j用于SpringCloud项目&#xff0c;它可以将某个url请求路由到指定的机器上&#xff0c;也可以将所有请求强制转到指定机器。 问题描述 Java后端在开发SpringCloud项目时如果同一个应用起了多个实例&#xff…...

深度解析对抗训练自编码器(Adversarial Autoencoder, AAE)

深度解析对抗训练自编码器&#xff08;Adversarial Autoencoder, AAE&#xff09; 在异常检测和生成模型领域&#xff0c;自编码器&#xff08;AutoEncoder&#xff09;通过压缩与重构学习数据的内在规律。然而&#xff0c;传统 AE 的隐藏空间&#xff08;Latent Space&#xf…...

Leetcode:单调栈系列

本人总结的单调栈大概有三类&#xff1a; 求右边第一个比该元素大&#xff08;小&#xff09;的元素求左边第一个比该元素大&#xff08;小&#xff09;的元素求两边比该元素大&#xff08;小&#xff09;的元素 前两类一般是中等难度的题&#xff0c;完成一次单调栈即可&…...

联合循环——23 电厂建筑屋顶防雷,盘柜中性点地排设计说明

一、屋顶防雷 &#xff08;1&#xff09;放电类型&#xff1a; 90%云对地放电是负极性&#xff0c;总的来说&#xff0c;放电开始于云端的负电荷而扩展到正电荷的地面。然而&#xff0c;大量的放电现象发生在云层之间。 &#xff08;2&#xff09;雷电波幅&#xff1a; 80%雷击…...

【广度优先搜索】【分类讨论】900. 最佳运动员的比拼回合

作者推荐 视频算法专题 本文涉及知识点 广度优先搜索 分类讨论 LeetCode : 1900. 最佳运动员的比拼回合 n 名运动员参与一场锦标赛&#xff0c;所有运动员站成一排&#xff0c;并根据 最开始的 站位从 1 到 n 编号&#xff08;运动员 1 是这一排中的第一个运动员&#xff…...

【计网】什么是移动计算?中国Java之父余胜军被刷爆的CDN又是什么?

目录 一、移动计算 1. 理解移动计算 2. 应用实例 二、数据缓存和内容分发网络&#xff08;CDN&#xff09; 1. 数据缓存 2. 内容分发网络&#xff08;CDN&#xff09; 3. CDN与数据缓存的联系 三、余胜军开了个网站&#xff0c;说CDN被刷爆了&#xff0c;他是什么意思&…...

史上最全msys2下载配置操作步骤

史上最全msys2下载配置操作步骤一&#xff0c;MSYS2简介二&#xff0c;软件下载三&#xff0c;pacman配置四&#xff0c;总结&#xff01;推荐参考B站视频&#xff1a;《3分钟搞定msys2的安装与配置》 一&#xff0c;MSYS2简介 面向Windows的软件分发与构建平台 MSYS2是一个…...

wow-iot 编码指南

项目地址&#xff1a;https://github.com/wow-iot3/wow_linux_eval 1、命名规则 &#xff08;1&#xff09;数据类型整数类型使用<stdint.h>内定义格式&#xff0c;约束为&#xff1a;int8_t/uint8_tint16_t/uint16_tint32_t/uint32_tint64_t/uint64_t&#xff08;2&…...

【大数据】分布式存储系统GFS与HDFS、高可用与高容错解析

目录 一、Chunk & Block 二、Master & Chunk Server&#xff1a;存储与计算的解耦&#xff1f; 1. 不准确&#xff01; 2. 调度与存储处理的解耦 解耦的具体含义 为什么这样设计&#xff1f; 3. NameNode & DataNode NameNode&#xff08;元数据管理&…...

PyCaret高性能计算:GPU加速训练指南

PyCaret高性能计算&#xff1a;GPU加速训练指南 【免费下载链接】pycaret An open-source, low-code machine learning library in Python 项目地址: https://gitcode.com/gh_mirrors/py/pycaret PyCaret是一个开源的低代码机器学习库&#xff0c;通过GPU加速功能可以显…...

pydata-book沟通技巧:如何向非技术人员解释数据分析结果

pydata-book沟通技巧&#xff1a;如何向非技术人员解释数据分析结果 【免费下载链接】pydata-book wesm/pydata-book: 这是Wes McKinney编写的《Python for Data Analysis》一书的源代码仓库&#xff0c;书中涵盖了使用pandas、NumPy和其他相关库进行数据处理和分析的实践案例和…...

从Swin到VMamba:视觉Transformer的效率革命

从Swin到VMamba&#xff1a;视觉Transformer的效率革命 【免费下载链接】VMamba 项目地址: https://gitcode.com/gh_mirrors/vm/VMamba 在计算机视觉领域&#xff0c;设计计算效率高的网络架构一直是持续的需求。随着视觉Transformer的发展&#xff0c;从Swin Transfor…...

终极SSH文件系统指南:sshfs如何让远程文件访问像本地一样简单

终极SSH文件系统指南&#xff1a;sshfs如何让远程文件访问像本地一样简单 【免费下载链接】sshfs File system based on the SSH File Transfer Protocol 项目地址: https://gitcode.com/gh_mirrors/ssh/sshfs sshfs是一款基于SSH文件传输协议的文件系统客户端&#xff…...

IEC 61850标准协议解读 5.基于Java的MMS实现 lec61850bean

专栏文章目录 第一章 IEC 61850标准协议解读 0.导言 第二章 IEC 61850标准协议解读 1.建模讲解 第三章 IEC 61850标准协议解读 2.基于Java的MMS实现 目录 专栏文章目录 前言 1 依赖库引入 2 创建服务端 3 创建客户端 4 读写模型 4.1 服务端读写 4.2 客户端读写 5.报告 6 文件服…...

wow-time时间操作说明

wow-time文件说明 项目地址&#xff1a;https://github.com/wow-iot3/wow_linux_eval本文件的功能主要用于处理时间操作&#xff0c;主要涉及时间信息获取(普通格式与cp56格式)、设置时间、格式转换、获取时间戳、获取毫秒数&#xff1b; 获取时间信息 int wow_time_get_cp56(C…...

探秘 ESCRCPY:一款高效便捷的无线屏幕镜像工具

探秘 ESCRCPY&#xff1a;一款高效便捷的无线屏幕镜像工具 【免费下载链接】escrcpy &#x1f4f1; Graphical Scrcpy to display and control Android, devices powered by Electron. | 使用图形化的 Scrcpy 显示和控制您的 Android 设备&#xff0c;由 Electron 驱动。 项目…...

100元打造便携显示器:PocketLCD完整物料清单与采购指南

100元打造便携显示器&#xff1a;PocketLCD完整物料清单与采购指南 【免费下载链接】PocketLCD 带充电宝功能的便携显示器 项目地址: https://gitcode.com/gh_mirrors/po/PocketLCD PocketLCD是一款带充电宝功能的便携显示器开源项目&#xff0c;让你花最少的成本拥有一…...

CGAL计算几何算法库完全指南:从入门到精通的终极教程

CGAL计算几何算法库完全指南&#xff1a;从入门到精通的终极教程 【免费下载链接】cgal The public CGAL repository, see the README below 项目地址: https://gitcode.com/gh_mirrors/cg/cgal CGAL&#xff08;Computational Geometry Algorithms Library&#xff09;…...

WHAT - 浏览器缓存机制系列(二)强缓存、协商缓存和启发式缓存

目录 一、介绍 二、强缓存 三、协商缓存 三、html & js 缓存策略 四、启发式缓存 启发式缓存什么时候发生 浏览器的推算规则 如果没有 Last-Modified DevTools 里怎么看出是启发式缓存 启发式缓存的风险 1. 浏览器行为不一致 2. 更新不可控 3. CDN 行为不同 总结 今天主要介…...

如何使用CoreRT:.NET Core终极AOT编译优化指南

如何使用CoreRT&#xff1a;.NET Core终极AOT编译优化指南 【免费下载链接】corert This repo contains CoreRT, an experimental .NET Core runtime optimized for AOT (ahead of time compilation) scenarios, with the accompanying compiler toolchain. 项目地址: https:…...