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。诉说着自己怀才不遇,天道不公时,咱们早就一头扎根在自己的事业中,闷声发大财,搞自己的事业,这才是最正确的,而不是像一个臭平民一样,几十个人聚集在一起,把帽子脱下来,在地下踩上几脚,又有什么用呢

相关推荐
凌肖战23 分钟前
力扣网C语言编程题:快慢指针来解决 “寻找重复数”
c语言·算法·leetcode
桂成林3 小时前
Hive UDF 开发实战:MD5 哈希函数实现
hive·hadoop·哈希算法
Alfred king13 小时前
面试150 生命游戏
leetcode·游戏·面试·数组
薰衣草233320 小时前
一天两道力扣(1)
算法·leetcode·职场和发展
爱coding的橙子20 小时前
每日算法刷题Day41 6.28:leetcode前缀和2道题,用时1h20min(要加快)
算法·leetcode·职场和发展
前端拿破轮1 天前
不是吧不是吧,leetcode第一题我就做不出来?😭😭😭
后端·算法·leetcode
前端拿破轮1 天前
😭😭😭看到这个快乐数10s,我就知道快乐不属于我了🤪
算法·leetcode·typescript
wsxqaz1 天前
浏览器原生控件上传PDF导致hash值不同
算法·pdf·哈希算法
今天背单词了吗9801 天前
算法学习笔记:4.KMP 算法——从原理到实战,涵盖 LeetCode 与考研 408 例题
笔记·学习·考研·算法·leetcode·kmp算法
hn小菜鸡1 天前
LeetCode 377.组合总和IV
数据结构·算法·leetcode