(LeetCode 面试经典 150 题) 169. 多数元素(哈希表 || 二分查找)

题目:169. 多数元素

方法一:二分法,最坏的时间复杂度0(nlogn),但平均0(n)即可。空间复杂度为0(1)。

C++版本:

cpp 复制代码
int n=nums.size();
        int l=0,r=n-1;
        while(l<r){
            int mid=(l+r)/2;
            int ans=0;
            for(auto x:nums){
                if(x==nums[mid]) ans++;
            }
            if(ans>n/2) break;
            else l=mid+1;
        }
        return nums[(l+r)/2];

JAVA版本:

java 复制代码
class Solution {
    public int majorityElement(int[] nums) {
        int n=nums.length;
        int l=0,r=n-1;
        while(l<r){
            int mid=(l+r)/2;
            int ans=0;
            for(var x:nums){
                if(x==nums[mid]) ans++;
            }
            if(ans>n/2) break;
            else l=mid+1;
        }
        return nums[(l+r)/2];
    }
}

Go版本:

go 复制代码
func majorityElement(nums []int) int {
    n:=len(nums)
    l,r:=0,n-1
    for l<r {
        mid:=(l+r)/2
        ans:=0
        for _,x:=range nums {
            if nums[mid]==x {
                ans++
            }
        }
        if ans>n/2 {
            break
        }else{
            l=mid+1
        }
    }
    return nums[(l+r)/2]
}

方法二:哈希表,时间复杂度0(n),空间复杂度0(n)。

C++版本:

cpp 复制代码
class Solution {
public:
    int majorityElement(vector<int>& nums) {
        unordered_map<int,int> mp;
        int n=nums.size();
        int res=0;
        for(auto x:nums){
            mp[x]++;
            if(mp[x]>n/2){
                res=x;
                break;
            }
        }
        return res;
    }
};

JAVA版本:

java 复制代码
class Solution {
    public int majorityElement(int[] nums) {
        Map<Integer,Integer> mp = new HashMap<>();
        int n=nums.length;
        int res=0;
        for(var x:nums){
            mp.put(x,mp.getOrDefault(x,0)+1);
            if(mp.get(x)>n/2){
                res=x;
                break;
            }
        }
        return res;
    }
}

Go版本:

go 复制代码
func majorityElement(nums []int) int {
    n:=len(nums)
    mp:=make(map[int]int)
    res:=0
    for _,x:=range nums {
        mp[x]++
        if mp[x]>n/2 {
            res=x
            break
        }
    }
    return res
}
相关推荐
曼巴UE59 分钟前
UE5 C++ JSON 最简单,麻烦的方式,直接读存(一)
java·服务器·前端
郝学胜-神的一滴25 分钟前
Effective STL 第9条:C++容器元素删除技巧详解
开发语言·c++·程序人生·stl
QMY52052032 分钟前
什么是爬虫?
java·eclipse
bbq粉刷匠32 分钟前
力扣--两数之和(Java)
java·leetcode
树在风中摇曳33 分钟前
LeetCode 1658 | 将 x 减到 0 的最小操作数(C语言滑动窗口解法)
c语言·算法·leetcode
mzlogin34 分钟前
解决访问 https 网站时,后端重定向或获取 URL 变成 http 的问题
java·后端·nginx
Ma_Hong_Kai34 分钟前
带复选框的combox
c++·mfc
江湖独行侠38 分钟前
认知神经科学解释生活中的现象——白月光、朱砂痣
java·服务器·生活·情绪
paopao_wu39 分钟前
DeepSeek-OCR实战(06):SpringBoot应用接入
java·spring boot·ai·ocr·deepseek
不夜牛仔1 小时前
算法笔记17 - 贪心算法介绍与思路 | 路灯摆放问题 | 活动安排问题 | 最低字典序拼接 | 金条分割问题 | 项目投资问题
笔记·算法·贪心算法