牛客题霸 [数组中出现次数超过一半的数字] C++题解/答案

题解:

题意很明确
跑一遍for循环,统计每个数出现的大小
然后再跑一边循环,查看是否存在大于一半的情况
注意题目要求是大于,没有等于

代码:

class Solution {
   
public:
    int MoreThanHalfNum_Solution(vector<int> numbers) {
   
        map<int,int>mp;
        for(int i=0;i<numbers.size();i++)
        {
   
            mp[numbers[i]]++;
        }
        for(int i=0;i<numbers.size();i++)
        {
   
           if(mp[numbers[i]]>(numbers.size()/2))return numbers[i];
        }
        return 0;
    }
};