(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
}
相关推荐
爱吃山竹的大肚肚4 分钟前
文件上传大小超过服务器限制
java·数据库·spring boot·mysql·spring
黄昏恋慕黎明4 分钟前
测试模型讲解
java
瑞雪兆丰年兮7 分钟前
[从0开始学Java|第十二天]学生管理系统升级
java·开发语言
弹简特7 分钟前
【JavaSE-网络部分03】网络原理-泛泛介绍各个层次
java·开发语言·网络
执风挽^7 分钟前
Python_func_basic
开发语言·python·算法·visual studio code
周杰伦的稻香7 分钟前
Hexo搭建教程
java·node.js
倔强的石头1068 分钟前
飞算JavaAI如何提升重塑Java开发体验
java·飞算javaai·ai开发工具
怪谈爱好者CMZ8 分钟前
【C++学习笔记】图论-最短路径Dijkstra算法
c++·笔记·学习
努力d小白11 分钟前
leetcode438.找到字符串中所有字母异位词
java·javascript·算法
短剑重铸之日11 分钟前
《设计模式》第九篇:三大类型之结构型模式
java·后端·设计模式·组合模式·代理模式·结构性模式