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

相关推荐
小沈同学呀15 分钟前
阿里巴巴高级Java工程师面试算法真题解析:LRU Cache实现
java·算法·面试
我今晚不熬夜1 小时前
使用单调栈解决力扣第42题--接雨水
java·数据结构·算法·leetcode
珍珠是蚌的眼泪1 小时前
LeetCode_哈希表
leetcode·哈希表·快乐数·字母异位词
flashlight_hi2 小时前
LeetCode 分类刷题:209. 长度最小的子数组
javascript·算法·leetcode
展信佳_daydayup3 小时前
0-1 深度学习基础——文件读取
算法
高斯林.神犇3 小时前
冒泡排序实现以及优化
数据结构·算法·排序算法
Github项目推荐3 小时前
跨平台Web服务开发的新选择(5802)
算法·架构
Jolyne_4 小时前
树节点key不唯一的勾选、展开状态的处理思路
前端·算法·react.js
秋难降4 小时前
正则表达式:为什么它成了程序员的 “分水岭”?
python·算法·正则表达式
岁忧4 小时前
(LeetCode 面试经典 150 题) 104. 二叉树的最大深度 (深度优先搜索dfs)
java·c++·leetcode·面试·go·深度优先