首页 > 其他分享 >多数元素

多数元素

时间:2022-08-14 12:23:07浏览次数:51  
标签:nums int 元素 num 数组 counts 多数

给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。
你可以假设数组是非空的,并且给定的数组总是存在多数元素。

示例 1:
输入:nums = [3,2,3]
输出:3

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


参考代码:

 

public int  majorityElement(int[] nums){
        Map<Integer,Integer> counts = new HashMap<Integer,Integer>();
        for(int i=0;i<nums.length;i++){
            counts.put(nums[i],counts.getOrDefault(nums[i],0)+1);
        }
        int majority = 0;
        //获取key的集合
        Set<Integer> keyset=counts.keySet();
        for(int num : keyset){
            if(counts.get(num)>(nums.length/2)){
                majority=num;
                break;
            }
        }
        return majority;

 

标签:nums,int,元素,num,数组,counts,多数
From: https://www.cnblogs.com/braveym/p/16585198.html

相关文章