机考刷题之 6 LeetCode 169 多数元素

题目

分析

思路一

第一时间想到的是拿一个unordered_map/map来存储每个值对应的频率,然后遍历这个unordered_map/map再得出主要元素。

代码

cpp 复制代码
class Solution {
public:
    int majorityElement(vector<int>& nums) {
        unordered_map<int,int>myMap;
        for(auto i:nums){
            myMap[i]++;
        }
        int maxCount = 0;
        int result = 0;
        for (auto& pair : myMap) {
            if (pair.second > maxCount) {
                maxCount = pair.second;
                result = pair.first;
            }
        }
        return result;
    }
};

结果

思路二

看到了提示尝试O(n)时间复杂度和O(1)的空间复杂度,查了一下,使用到了Boyer-Moore投票法,关于这个算法的讲解,这篇文章讲得很全面,核心思想就是针对于存在主要元素的数组,将两个不同的元素两两消去,剩下的就一定是主要元素(因为确保了存在主要元素)。

代码

cpp 复制代码
class Solution {
public:
    int majorityElement(vector<int>& nums) {
        int candidate = 0, count = 0;
        for (int num : nums) {
            if (count == 0) {
                candidate = num;
            }
            count += (num == candidate) ? 1 : -1;
        }
        return candidate;
    }
};

结果

相关推荐
圣保罗的大教堂2 小时前
leetcode 1980. 找出不同的二进制字符串 中等
leetcode
Neteen2 小时前
【数据结构-思维导图】第二章:线性表
数据结构·c++·算法
礼拜天没时间.2 小时前
力扣热题100实战 | 第25期:K个一组翻转链表——从两两交换到K路翻转的进阶之路
java·算法·leetcode·链表·递归·链表反转·k个一组翻转链表
Swift社区3 小时前
LeetCode 400 第 N 位数字
算法·leetcode·职场和发展
再难也得平3 小时前
力扣239. 滑动窗口最大值(Java解法)
算法·leetcode·职场和发展
摩尔曼斯克的海3 小时前
力扣面试题--双指针类
python·算法·leetcode
灰色小旋风3 小时前
力扣——第7题(C++)
c++·算法·leetcode
故事和你914 小时前
sdut-程序设计基础Ⅰ-实验二选择结构(1-8)
大数据·开发语言·数据结构·c++·算法·优化·编译原理
努力学算法的蒟蒻4 小时前
day106(3.7)——leetcode面试经典150
算法·leetcode·面试