1.10 面试经典150题-多数元素

多数元素

Go

go 复制代码
func majorityElement(nums []int) int {
    numMap := make(map[int]int)
    for _, v := range nums {
        n, ok := numMap[v]
        if ok {
            numMap[v] = n + 1
        } else {
            numMap[v] = 1
        }
        if numMap[v] > len(nums) / 2 {
            return v
        }
    }
    return -1
}

解题思路:采用map结构保存每个元素出现的次数,当找到某个值出现次数超过半数后,则返回

python

python 复制代码
class Solution:
    def majorityElement(self, nums: List[int]) -> int:
        nums.sort()
        return nums[len(nums) // 2]

解题思路:排序后,有序数组的中位数则为多数元素

相关推荐
c++逐梦人2 小时前
二分查找模版及二分答案例题
算法·蓝桥杯
biubiuibiu2 小时前
选择适合的硬盘:固态与机械硬盘的对比与推荐
c++·算法
big_rabbit05022 小时前
[算法][力扣226]翻转一颗二叉树
数据结构·算法·leetcode
TracyCoder1232 小时前
LeetCode Hot100(65/100)——64. 最小路径和
算法·leetcode·职场和发展
z2014z2 小时前
Deflate 算法详解
网络·算法
条tiao条2 小时前
从 “Top-K 问题” 入门二叉堆:C 语言从零实现与经典应用
c语言·算法·深度优先
uesowys2 小时前
华为OD算法开发指导-数据结构-图
数据结构·算法·华为od
实心儿儿2 小时前
算法3:链表分割
数据结构·算法·链表
Tisfy2 小时前
LeetCode 1415.长度为 n 的开心字符串中字典序第 k 小的字符串:DFS构造 / 数学O(n)
数学·算法·leetcode·深度优先·字符串·dfs·模拟