[数组排序] 0169. 多数元素

文章目录

      • [1. 题目链接](#1. 题目链接)
      • [2. 题目大意](#2. 题目大意)
      • [3. 示例](#3. 示例)
      • [4. 解题思路](#4. 解题思路)
      • [5. 参考代码](#5. 参考代码)

1. 题目链接

169. 多数元素 - 力扣(LeetCode)


2. 题目大意

描述:给定一个大小为 n 的数组 nums

要求:返回其中相同元素个数最多的元素。

说明:

  • n==nums.length。
  • 1≤n≤5∗104。
  • −109≤nums[i]≤109。

3. 示例

java 复制代码
输入:nums = [3,2,3]
输出:3
java 复制代码
输入:nums = [2,2,1,1,1,2,2]
输出:2

4. 解题思路

  1. 遍历数组 nums
  2. 对于当前元素 num,用哈希表统计每个元素 num 出现的次数。
  3. 再遍历一遍哈希表,找出元素个数最多的元素即可。

5. 参考代码

java 复制代码
class Solution {
    public int majorityElement(int[] nums) {
        int x=0, vote=0;
        for(int num : nums){
            if(vote==0) x=num;
            vote += num==x ? 1 : -1;
        }
        return x;
    }
}

相关推荐
m0_69493801几秒前
Leetcode打卡:最小区间
算法·leetcode·职场和发展
使者大牙18 分钟前
【LLM学习笔记】第四篇:模型压缩方法——量化、剪枝、蒸馏、分解
人工智能·深度学习·算法·机器学习
Matlab程序猿小助手19 分钟前
【MATLAB源码-第222期】基于matlab的改进蚁群算法三维栅格地图路径规划,加入精英蚁群策略。包括起点终点,障碍物,着火点,楼梯。
开发语言·人工智能·算法·matlab·机器人·无人机
迷迭所归处23 分钟前
优先算法 —— 双指针系列 - 复写零
算法
向前看-29 分钟前
青训营刷题笔记17
c++·笔记·算法
l138494274511 小时前
Java综合练习
java·开发语言·算法
z0006161 小时前
C语言之函数的参数
c语言·数据结构·算法
St_Ludwig2 小时前
蓝桥杯疑似例题解答方案(打印任意阶杨辉三角)
c语言·c++·后端·算法·职场和发展·蓝桥杯
心.c2 小时前
0-1背包问题
c++·算法
kitesxian2 小时前
Leetcode146. LRU 缓存(HOT100)
数据结构·算法·leetcode·缓存