Majority Element

Given an array of size n, find the majority element. The majority element is the element that appears more than ⌊ n/2 ⌋ times.

You may assume that the array is non-empty and the majority element always exist in the array.

思路 1 : 用 hashmap  来存储每个数字出现的次数, 如果有一个次数超过 n/2 , 就返回。

思路 2 : 设置一个数字 和 次数, 如果相同, 则次数加一, 否则减一, 如果减到0, 就更新。

因此, 如果一个数字的出现次数超过一半, 他肯定会被保留下来。

public class Solution {
    public int majorityElement(int[] num) {
        if(num.length < 1)
            return -1;
        HashMap<Integer, Integer> map = new HashMap<Integer, Integer>();
        int len = num.length;
        for(int i = 0; i < len; i++){
            if(map.containsKey(num[i])){
                int times = map.get(num[i]);
                map.put(num[i], times + 1);
                if(times + 1 > len / 2)
                    return num[i];
            }else{
                map.put(num[i], 1);
                if(len == 1)
                    return num[i];
            }
        }
        return -1;
    }
}
public class Solution {
    public int majorityElement(int[] sum) {
                int majority=sum[0];
                 int times=1;
                 for(int i=1;i<sum.length;i++)
                 {
                      if(majority==sum[i])
                           times++;
                      else
                      {
                           times--;
                           if(times==0)
                           {
                                times=1;
                                majority=sum[i];
                           }
                      }
                 }
                 return majority;
    }
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值