【力扣hot100题】(096)多数元素

感觉这题应该是中等题,方法很多但思考起来还是有难度的。

最简单的方法是排序后找中位数,因为多数元素占一半以上所以排序后的数组中位数一定是多数元素。

我最先想到的方法是两个两个删除,每次删除两个不同元素,最终剩下的那些就一定是多数元素。

但是代码有点难写:

cpp 复制代码
class Solution {
public:
    int majorityElement(vector<int>& nums) {
        for(int i=0;i<nums.size()-1;i++){
            if(nums[i]!=nums[i+1]){
                nums.erase(nums.begin()+i,nums.begin()+i+2);
                if(i==0) i--;
                else i-=2;
            }
        }
        return nums[0];
    }
};

然后我发现时间复杂度有点高,因为有时候会回溯比较浪费时间,然后我就看到一种非常巧妙的思路:

cpp 复制代码
class Solution {
public:
    int majorityElement(vector<int>& nums) {
        int result;
        int count=0;
        for(int i=0;i<nums.size();i++){
            if(count==0) result=nums[i];
            if(result==nums[i]) count++;
            else count--;
        }
        return result;
    }
};

代码可能有点难看懂,思路是先定下一个元素,遍历数组时记录它出现的"频率"(若当前元素是该元素则加一,若不是则减一),当count为0时说明在定下这个数之后的这段数组中这个数不是这段的多数元素,因为这段数组中这个数的出现频率没有达到一半,于是就可以换下一个数定位......

这样做一定可以排除掉不是多数元素的元素,遍历完全部最后count不为0的数一定就是那个多数元素。

相关推荐
yyy(十一月限定版)7 分钟前
寒假集训4——二分排序
算法
星火开发设计7 分钟前
类型别名 typedef:让复杂类型更简洁
开发语言·c++·学习·算法·函数·知识
醉颜凉18 分钟前
【LeetCode】打家劫舍III
c语言·算法·leetcode·树 深度优先搜索·动态规划 二叉树
达文汐21 分钟前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗21 分钟前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl
User_芊芊君子21 分钟前
【LeetCode经典题解】搞定二叉树最近公共祖先:递归法+栈存路径法,附代码实现
算法·leetcode·职场和发展
培风图南以星河揽胜22 分钟前
Java版LeetCode热题100之零钱兑换:动态规划经典问题深度解析
java·leetcode·动态规划
算法_小学生23 分钟前
LeetCode 热题 100(分享最简单易懂的Python代码!)
python·算法·leetcode
执着25923 分钟前
力扣hot100 - 234、回文链表
算法·leetcode·链表
Gorgous—l25 分钟前
数据结构算法学习:LeetCode热题100-多维动态规划篇(不同路径、最小路径和、最长回文子串、最长公共子序列、编辑距离)
数据结构·学习·算法