机考刷题之 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;
    }
};

结果

相关推荐
小O的算法实验室18 分钟前
2026年SEVC,面向主动成像卫星任务规划问题的群体智能与动态规划混合框架,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
网安INF28 分钟前
数据结构第一章复习:基本概念与算法复杂度分析
数据结构·算法
幻风_huanfeng1 小时前
人工智能之数学基础:什么是凸优化问题?
人工智能·算法·机器学习·凸优化
三雷科技1 小时前
使用 `dlopen` 动态加载 `.so` 文件
开发语言·c++·算法
Yzzz-F1 小时前
Problem - 2146D1 - Codeforces &&Problem - D2 - Codeforces
算法
Kk.08021 小时前
力扣 LCR 084.全排列||
算法·leetcode·职场和发展
环黄金线HHJX.1 小时前
龙虾钳足启发的AI集群语言交互新范式
开发语言·人工智能·算法·编辑器·交互
Omics Pro1 小时前
虚拟细胞:开启HIV/AIDS治疗新纪元的关键?
大数据·数据库·人工智能·深度学习·算法·机器学习·计算机视觉
旖-旎2 小时前
分治(快速选择算法)(3)
c++·算法·leetcode·排序算法·快速选择
_日拱一卒2 小时前
LeetCode:合并区间
算法·leetcode·职场和发展