LeetCode做题记录(第二天)169. 多数元素

题目:169. 多数元素

标签:数组 哈希表 分治 计数 排序

题目信息:

思路一:

在题目中出现了计数,那我们就可以直接考虑考虑使用哈希表

unordered_map

即遍历的时候记录每个数的出现次数,当出现次数大于n/2时,则返回这个数,这样就可以完成题目了。

代码实现:

cpp 复制代码
class Solution {
public:
    int majorityElement(vector<int>& nums) {
        unordered_map<int,int>mp;//元素:出现次数
        int n=nums.size();
        int falg = n/2;
        for(int i=0;i<n;i++){
            mp[nums[i]]++;
            if(mp[nums[i]]>falg){
                return nums[i];
            }
        }
        return 0;
    }
};

时间复杂度分析:

一层for,O(n)

思路二:

这个思路是我在评论区看到的,很巧妙。

他把这个比作是帮派大乱斗,由于有个帮派的人数始终大于n/2,那么在大乱斗一换一的情况下,最后活着的人一定是这个帮派。

代码实现:

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

时间复杂度分析:

一层for,也是O(n)

但是由于没有开新的空间,所以空间复杂度很小,O(1)

总结:

出现计数相关的就考虑哈希表

ps:哇,做题写题解真是花时间但又不得不做。还是得好好规划时间。主要还是抖音太费时间,加油加油,加油沉淀。

补充下我最近在一个群里看到群友发出来的话,让我很有触动:

还没开始干,还没学习java基础,就开始拉群问自己有没有可能学得会,还没开始投简历之前就在群里抱怨社会不公平。你就算知道世界不公平,那有什么用呢?也就只是和一堆负能量的人聚集在一起,不光得不到什么情绪价值,每天还会被别人影响,干扰你的判断能力。两个教训总结,跟着别人的节奏一起吐槽。殊不知人家吃穿不愁。而你,浪费你的大把时间。我要是及早醒悟,早点远离这些神经病,内鬼,当别人还在抱怨social的不公,聚集起来批判social。诉说着自己怀才不遇,天道不公时,咱们早就一头扎根在自己的事业中,闷声发大财,搞自己的事业,这才是最正确的,而不是像一个臭平民一样,几十个人聚集在一起,把帽子脱下来,在地下踩上几脚,又有什么用呢

相关推荐
Learner__Q5 小时前
每天五分钟:滑动窗口-LeetCode高频题解析_day3
python·算法·leetcode
阿昭L5 小时前
leetcode链表相交
算法·leetcode·链表
松涛和鸣5 小时前
Linux Makefile : From Basic Syntax to Multi-File Project Compilation
linux·运维·服务器·前端·windows·哈希算法
小南家的青蛙7 小时前
LeetCode第1261题 - 在受污染的二叉树中查找元素
算法·leetcode·职场和发展
玖剹7 小时前
记忆化搜索题目(二)
c语言·c++·算法·leetcode·深度优先·剪枝·深度优先遍历
Jul1en_8 小时前
【算法】分治-归并类题目
java·算法·leetcode·排序算法
java修仙传9 小时前
力扣hot100:寻找旋转排序数组中的最小值
算法·leetcode·职场和发展
F_D_Z11 小时前
哈希表解Two Sum问题
python·算法·leetcode·哈希表
LYFlied11 小时前
【每日算法】LeetCode124. 二叉树中的最大路径和
数据结构·算法·leetcode·面试·职场和发展
talenteddriver12 小时前
java: Java8以后hashmap扩容后根据高位确定元素新位置
java·算法·哈希算法