【技巧】Leetcode 169. 多数元素【简单】

多数元素

给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。

你可以假设数组是非空的,并且给定的数组总是存在多数元素。

示例 :

输入:nums = [2,2,1,1,1,2,2]
输出:2

解题思路

可以利用摩尔投票法(Boyer-Moore Voting Algorithm)。这个算法的基本思想是:

  • 维护一个候选众数,初始化为数组的第一个元素,然后遍历数组,
  • 对于每个元素,如果计数为0,则将当前元素设置为候选众数,
  • 否则如果当前元素等于候选众数,则计数加一,否则计数减一。

核心思想:通过抵消不同的元素,最终剩下的就是多数元素。

  • 由于题目已经保证多数元素一定存在,且出现次数大于 ⌊ n/2 ⌋,所以这种投票法一定会得到正确的结果。

Java实现

public class MajorityElement {public static int majorityElement(int[] nums) {int candidate = nums[0];int count = 1;for (int i = 1; i < nums.length; i++) {if (count == 0) {candidate = nums[i];count = 1;} else if (nums[i] == candidate) {count++;} else {count--;}}return candidate;}public static void main(String[] args) {int[] nums = {3, 2, 4, 3, 4, 4, 2, 4, 4};System.out.println(majorityElement(nums));}
}

时间空间复杂度

  • 时间复杂度:O(n),其中n为数组nums的长度。因为只需遍历一次数组。

  • 空间复杂度:O(1)。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/613.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

day22 java多线程 线程安全问题解决方案

线程安全问题 [面试题]继承Thread和实现Runnable有什么区别&#xff1f; 1.实现接口和继承类 - 实现接口更灵活因为可以多实现。 2.线程安全 同步代码块 &#xff1a; 继承Thread : 锁不可以是this 实现Runnable : 锁可以是this 同步方法 继承Thread : 同步方法要使用静态同步…

修改taro-ui-vue3的tabs组件源码增加数字标签

需求&#xff1a;taro-ui-vue3的tabs组件上增加数字标记 步骤一&#xff1a;node_modules文件夹下找到taro-ui-vue3/lib/tabs/index.js 把173行的这一段替换成下面这段&#xff0c;然后写上样式 default: () > item.number ? [h(View, {class: at-tabs__item_in}, {defau…

Unity导出package

C#代码导出后为一个dll&#xff0c;原有的不同平台的库不变。 以下操作均在build PC 平台下操作。 1.在要导出的文件夹下建assembly definition (Any platform) 2.将项目文件夹下的\Library\ScriptAssemblies中的相应assembly definition的dll复制到要导出的文件夹下 3.在uni…

gstreamer pad cap的协商

这是在大模型中获取的答案&#xff0c;有点意思。 在 GStreamer 中&#xff0c;大多数时候 pad 协商是通过框架自动完成的&#xff0c;并且不需要手动干预。但是&#xff0c;了解如何在代码里面执行 pad 协商是很有帮助的&#xff0c;这在创建自定义元素或更细致地控制数据流时…

关于Pwn的一些文章

关于Pwn的一些文章 仅仅是本人为了方便查阅资料而已 1、保护机制&#xff1a; https://www.zhihu.com/question/464671097/answer/3257122786https://blog.csdn.net/m0_71081503/article/details/127732602 2、DA常用快捷键及其作用 https://blog.csdn.net/weixin_4574396…

基于Java+SpringBoot+Vue前后端分离仓库管理系统

基于JavaSpringBootVue前后端分离仓库管理系统 &#x1f345; 作者主页 央顺技术团队 &#x1f345; 欢迎点赞 &#x1f44d; 收藏 ⭐留言 &#x1f4dd; &#x1f345; 文末获取源码联系方式 &#x1f4dd; &#x1f345; 查看下方微信号获取联系方式 承接各种定制系统 &#…

Vue3基本功能介绍

文章目录 Vue3组件中的模板结构可以没有根标签div组合式APIRefReactive函数回顾Vue2响应式Vue3实现响应式对比reactive和refSetup注意点计算属性与监听computedWatchWatchEffectVue3生命周期自定义hook函数toRef其他组合APIshallowReactiveshallowRefreadonly和shallowOnlyToRa…

算法设计与分析实验4 :利用动态规划的方法解决子集等和分割判断问题

实验4 利用动态规划的方法解决子集等和分割判断问题 一、实验目的 1. 了解动态规划的主要思想。 2. 掌握背包问题解决方法用以解决该问题。 3. 分析核心代码的时间复杂度和空间复杂度。 二、实验内容和要求 题目:给定一个只包含正整数的非空数组。是否可以将这个数组分…

赋能企业高效精准的EDM邮件群发推广

数字化营销日益成为商业增长引擎&#xff0c;云衔科技以其创新的智能EDM&#xff08;Electronic Direct Mail&#xff09;邮件群发推广解决方案&#xff0c;帮助企业客户突破传统营销模式&#xff0c;实现业绩飞跃和品牌影响力的大幅提升。 作为数字化广告营销及SaaS软件服务领…

安装mysql5.7.26一个报错问题

首先先安装mysql5.7.26,因为要求安装的版本要和原来的一样&#xff0c;数据路径也要和原来一致 一、安装mysql5.7.26 mysql官网各种版本下载网址 MySQL :: Download MySQL Community Server (Archived Versions) 1、下载mysql安装包 2、环境准备 centos7.9 mysql5.7.26包…

【简单介绍下Faiss原理和使用】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…

有哪些公认好用且免费的云渲染网渲平台?渲染100邀请码1a12

现在云渲染是越来越火了&#xff0c;无论是在建筑设计、影视动画还是效果图行业都有它的身影&#xff0c;云渲染能缩短制作周期&#xff0c;提高工作效率&#xff0c;那么市面上有哪些公认好用且免费的云渲染平台呢&#xff1f;这次我们来了解下。 首先&#xff0c;我们来看看有…

Linux:nmcli网络配置

Linux&#xff1a;nmcli网络配置 作用&#xff1a;nmcli&#xff0c;可以实现创建&#xff0c;显示&#xff0c;编辑&#xff0c;删除&#xff0c;激活和停用网络连接以及控制和显示网络设备状态等查看网卡信息&#xff08;这个在排查网络配置错误时很有用&#xff09; [root…

牛客Linux高并发服务器开发学习第三天

静态库的使用(libxxx.a) 将lession04的文件复制到lession05中 lib里面一般放库文件 src里面放源文件。 将.c文件转换成可执行程序 gcc main.c -o app main.c当前目录下没有head.h gcc main.c -o app -I ./include 利用-I 和head所在的文件夹&#xff0c;找到head。 main.c…

Redis中的Lua脚本(五)

Lua脚本 脚本复制 复制EVALSHA命令 EVALSHA命令式所有与Lua脚本有关的命令中&#xff0c;复制操作最复杂的一个&#xff0c;因为主服务器与从服务器载入Lua脚本的情况可能有所不同&#xff0c;所以主服务器不能像复制EVAL命令、SCRIPT LOAD命令或者SCRIPT FLUSH命令那样&…

Ubuntu鼠标自动点击脚本-工具xdotool简单使用

1 安装xdotool sudo apt-get install xdotool2 xdotool基本指令 移动鼠标 #设置屏幕位置 x_ 300 y_ 400 xdotool mousemove x_ y_点击鼠标 xdotool mousemove x_ y_ click 1设置动作间隔 #暂停2s sleep 23简单的bash脚本 move_mouse.sh iterations 2000for ((i0; i&l…

CentOS 7 上安装 MySQL 8.0详细步骤

CentOS 7 上安装 MySQL 8.0.30&#xff1a;详细步骤 准备阶段 下载 MySQL 安装包 前往 MySQL Archives&#xff0c;选择适合 CentOS 7 的安装包。 关闭防火墙和 SELinux # 临时关闭防火墙 systemctl stop firewalld.service # 永久关闭防火墙 systemctl disable firewalld.se…

k8s的服务Service暴露应用

k8s的服务Service暴露应用 Kubernetes&#xff08;k8s&#xff09;是一个开源的容器编排系统&#xff0c;用于自动化应用部署、扩展和管理。在k8s中&#xff0c;Service是管理Pod访问的关键组件&#xff0c;它允许你定义如何访问运行在集群中的Pod。本文将详细介绍Service的概…

第七节 LLAVA模型训练流程与方法

文章目录 前言一、训练模式方法二、lora形式fitune训练步骤第一步:lora形式fitune的launch.json配置第二步:train_mem.py第三步:模型参数配置(train())第四步:语言模型加载第五步:语言模型梯度、量化、lora训练方法设定第六步:语言模型的tokenizer第七步:根据model_ar…

[大模型]Qwen-7B-Chat 接入langchain搭建知识库助手

Qwen-7B-Chat 接入langchain搭建知识库助手 环境准备 在autodl平台中租一个3090等24G显存的显卡机器&#xff0c;如下图所示镜像选择PyTorch–>2.0.0–>3.8(ubuntu20.04)–>11.8 接下来打开刚刚租用服务器的JupyterLab&#xff0c;并且打开其中的终端开始环境配置…