• 【面试】找到一个数组中超过一半的数——摩尔投票算法


    摩尔投票算法

    思路

    算法首先将数组的第一个元素作为候选众数,并设置初始计数为1。然后,遍历数组中的每个元素,如果当前元素等于候选众数,则增加计数,否则减少计数。当计数降为0时,算法更换候选众数为当前元素,并重置计数。最终,候选众数即为超过一半的数。

    原理

    这个算法之所以有效,是因为多数元素的出现次数一定超过其他所有元素的出现次数之和。通过不断抵消不同的元素,最终候选众数将是多数元素。

    C++实现

    #include 
    #include 
    
    int findMajorityElement(std::vector<int>& nums) {
        int majority = nums[0];  // 候选的众数
        int count = 1;           // 候选众数的计数
    
        for (int i = 1; i < nums.size(); ++i) {
            if (nums[i] == majority) {
                // 如果当前元素等于候选众数,则增加计数
                ++count;
            } else {
                // 如果当前元素不等于候选众数,则减少计数
                --count;
                if (count == 0) {
                    // 当计数降为0时,更换候选众数为当前元素
                    majority = nums[i];
                    count = 1;
                }
            }
        }
    
        // 最终的候选众数即为超过一半的数
        return majority;
    }
    
    int main() {
        std::vector<int> nums = {2, 2, 1, 1, 1, 2, 2};
        int majorityElement = findMajorityElement(nums);
        std::cout << "Majority Element: " << majorityElement << std::endl;
        return 0;
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33

    复杂度

    摩尔投票算法的时间复杂度为O(n),其中n是数组的长度,因为它只需要遍历数组一次。这使得它成为在大型数据集中找到多数元素的高效方法。

  • 相关阅读:
    [附源码]Python计算机毕业设计Django高校商铺管理系统论文
    字符加密A--E,B-F,W--A
    HTML5详解
    数据结构之时空复杂度
    Mysql-数据丢失,分析binlog日志文件
    病例演讲比赛PPT模板
    SLD60N02T美浦森20V 60A N沟道 MOS管
    详解CPU的态
    知识蒸馏原理与PVKD论文阅读
    nginx反向代理配置
  • 原文地址:https://blog.csdn.net/weixin_36313227/article/details/133270790