(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
}
相关推荐
侠客行03174 小时前
Mybatis连接池实现及池化模式
java·mybatis·源码阅读
蛇皮划水怪4 小时前
深入浅出LangChain4J
java·langchain·llm
老毛肚6 小时前
MyBatis体系结构与工作原理 上篇
java·mybatis
那个村的李富贵6 小时前
CANN加速下的AIGC“即时翻译”:AI语音克隆与实时变声实战
人工智能·算法·aigc·cann
风流倜傥唐伯虎6 小时前
Spring Boot Jar包生产级启停脚本
java·运维·spring boot
power 雀儿6 小时前
Scaled Dot-Product Attention 分数计算 C++
算法
Yvonne爱编码6 小时前
JAVA数据结构 DAY6-栈和队列
java·开发语言·数据结构·python
Re.不晚6 小时前
JAVA进阶之路——无奖问答挑战1
java·开发语言
熬夜有啥好6 小时前
数据结构——哈希表
数据结构·散列表
你这个代码我看不懂6 小时前
@ConditionalOnProperty不直接使用松绑定规则
java·开发语言