[数组排序] 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;
    }
}

相关推荐
Kt&Rs8 分钟前
11.11 LeetCode 题目汇总与解题思路
算法·leetcode·哈希算法
py有趣12 分钟前
LeetCode算法学习之有效的字母异位词
学习·算法·leetcode
Learn Beyond Limits30 分钟前
Clustering vs Classification|聚类vs分类
人工智能·算法·机器学习·ai·分类·数据挖掘·聚类
chao18984433 分钟前
遗传算法与粒子群算法优化BP提高分类效果
算法·分类·数据挖掘
ScilogyHunter35 分钟前
卫星姿态控制模式全解析:从基准到任务的体系化分类
算法·分类
gihigo19983 小时前
MATLAB数值分析方程求解方法详解
算法·机器学习·matlab
程序员buddha6 小时前
C语言数组详解
c语言·开发语言·算法
蒙奇D索大8 小时前
【算法】递归算法的深度实践:从布尔运算到二叉树剪枝的DFS之旅
笔记·学习·算法·leetcode·深度优先·剪枝
卡提西亚8 小时前
C++笔记-25-函数模板
c++·笔记·算法
ghie90908 小时前
MATLAB/Simulink水箱水位控制系统实现
开发语言·算法·matlab