【剑指 Offer 39】数组中超过一半的数字

题目:

数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。

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

示例:

输入: [1, 2, 3, 2, 2, 2, 5, 4, 2]

输出: 2

思考:

  • 方法一:投机取巧

  • 将数组排序,出现次数超过一半的数字肯定在数组中间的那个位置

题解:

java 复制代码
class Solution {
    public int majorityElement(int[] nums) {
        Arrays.sort(nums);
        return nums[nums.length / 2];
    }
}

思考:

  • 方法二:哈希表辅助

  • 使用一个 map,key 存数组中的数字,val 存出现的次数

  • 当有数字出现次数超过数组长度一半时,直接返回

题解:

java 复制代码
class Solution {
    public int majorityElement(int[] nums) {
        Map<Integer,Integer> map = new HashMap<>();

        for(int num : nums){
            map.put(num,map.getOrDefault(num,0)+1);
            if(map.get(num)> nums.length>>1) return num;
        }
        return 0;
    }
}

思考:

  • 方法三,摩尔投票法

  • 众数和非众数投票,初始票数为 0,为 0 时假设当前数字为众数

  • 遍历数组,是众数 +1,不是众数 -1,为 0 就接着继续重新来

  • 最后得到众数

题解:

java 复制代码
class Solution {
    public int majorityElement(int[] nums) {
        int vote = 0;
        int x = 0;
        for (int i = 0; i < nums.length; i++) {

            if (vote == 0) x = nums[i];

            if (x == nums[i]) vote++;
            else vote--;
        }
        return x;
    }
}
相关推荐
xxxxxmy6 分钟前
同向双指针(滑动窗口)
python·算法·滑动窗口·同向双指针
释怀°Believe13 分钟前
Daily算法刷题【面试经典150题-5️⃣图】
算法·面试·深度优先
List<String> error_P15 分钟前
数据结构:链表-单向链表篇
算法·链表
ss27320 分钟前
ConcurrentHashMap:扩容机制与size()方法
算法·哈希算法
lkbhua莱克瓦2421 分钟前
Java进阶——IO流
java·开发语言·笔记·学习方法·io流
韩立学长22 分钟前
【开题答辩实录分享】以《自选便利店商品分类管理系统》为例进行选题答辩实录分享
java·mysql·web
阿杰同学25 分钟前
Java中55种锁,高级面试题,最新面试题
java·开发语言
2401_8603195227 分钟前
在React Native鸿蒙跨平台开发中实现一个冒泡排序算法并将其应用于数据排序,如何进行复制数组以避免直接修改状态中的数组
javascript·算法·react native·react.js·harmonyos
清晓粼溪27 分钟前
SpringCloud01-基础概念
java·开发语言·spring cloud
im_AMBER28 分钟前
Leetcode 72 数组列表中的最大距离
c++·笔记·学习·算法·leetcode