LeetCode热题100 多数元素

题目描述

给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。

你可以假设数组是非空的,并且给定的数组总是存在多数元素。

示例 1:

输入: nums = 3,2,3
输出: 3

示例 2:

输入: nums = 2,2,1,1,1,2,2
输出: 2

提示:

n == nums.length
1<=n<=5∗1041 <= n <= 5 * 10^41<=n<=5∗104
−109<=numsi<=109-10^9 <= numsi <= 10^9−109<=numsi<=109

输入保证数组中一定有一个多数元素。

进阶:尝试设计时间复杂度为 O(n)、空间复杂度为 O(1) 的算法解决此问题。

思路

我们将某个值设置为众数,进行一次遍历。

遇到改值+1,不是该值-1,减到-1时候,修改成现在这个值为众数,直到遍历结束,这个值就是答案。

证明:
若众数和其他数抵消,最后不会小于0。
若其他数互相抵消,那更好了,最后众数更不会小于0。

代码

cpp 复制代码
class Solution {
public:
    int majorityElement(vector<int>& nums) {
        int cnt = 0;
        int now = 0;
        for(auto num : nums)
        {
            if(num == now)
            {
                ++cnt;
            }
            else
            {
                --cnt;
                if(cnt == -1)
                {
                    now = num;
                    cnt = 1;
                }
            }
        }
        return now;
    }
};
相关推荐
葡萄城技术团队几秒前
观察生活:人是如何分词的
算法·生活
草莓熊Lotso2 分钟前
【Linux网络】深入理解 HTTP 协议(一):从基础概念到 URL 编码解码
linux·网络·c++·网络协议·http·软件工程
眠りたいです2 分钟前
现代C++:C++17中的新语言特性
开发语言·c++·c++17
一只旭宝4 分钟前
【C++入门精讲17】序列容器
开发语言·c++
装不满的克莱因瓶6 分钟前
什么是特征分解?从数学定义到现实问题的映射
人工智能·数学·算法·机器学习·ai·特征分解
killerbasd11 分钟前
总结 6.1
算法
郝学胜-神的一滴11 分钟前
Qt 高级开发 021:零基础吃透 QVBoxLayout 垂直布局
开发语言·c++·qt·程序人生·用户界面
basketball61614 分钟前
C++进阶:2. std::move 和 std::forward 函数
java·开发语言·c++
「維他檸檬茶」14 分钟前
大模型算法学习2026.6.1
学习·算法·大模型·nlp