zoukankan      html  css  js  c++  java
  • 【剑指Offer】面试题39. 数组中出现次数超过一半的数字

    题目

    数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字。
    你可以假设数组是非空的,并且给定的数组总是存在多数元素。

    示例 1:

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

    限制:1 <= 数组长度 <= 50000

    本题同

    思路一:哈希表

    统计每个数出现次数,然后查找出现次数超过一半的数。

    代码

    时间复杂度:O(n)
    空间复杂度:O(n)

    class Solution {
    public:
        int majorityElement(vector<int>& nums) {
            int size = nums.size();
            unordered_map<int, int> ump;
            for (auto n : nums) {
                if (ump.count(n) == 0) ump.insert({n, 1});
                else ++ump[n];
            }
            for (auto it = ump.begin(); it != ump.end(); ++it) {
                if (it->second > size / 2) return it->first;
            }
            return -1;
        }
    };
    

    思路二:投票

    初始假设第一个数出现次数最大,然后遍历每个数,如果遇到相同,则次数加1,否则次数减1,如果次数大于一半0,则直接返回,如果次数为0,则重置当前数为出现次数最多数。

    代码

    时间复杂度:O(n)
    空间复杂度:O(1)

    class Solution {
    public:
        int majorityElement(vector<int>& nums) {
            int size = nums.size();
            int res = nums[0], cnt = 1;
            for (int i = 1; i < size; ++i) {
                if (nums[i] == res) ++cnt;
                else --cnt;
                if (cnt > size / 2) return res;
                if (cnt == 0) {                
                    res = nums[i];
                    cnt = 1;
                }            
            }
            return res;
        }
    };
    
  • 相关阅读:
    uva 562
    uva 624
    hdu 3826
    CF 89 div2 A
    看视屏学编程之接口、抽象类
    看视频学编程之SQL数据库基础
    看视频学编程之WinForm
    看视频学编程之骑士飞行棋—自己做(单机版)
    看视频学编程之继承
    看视频学编程之C#中的类
  • 原文地址:https://www.cnblogs.com/galaxy-hao/p/12663264.html
Copyright © 2011-2022 走看看