算法(TS):多数元素

给定一个大小为 n 的数组 nums ,返回其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。

你可以假设数组是非空的,并且给定的数组总是存在多数元素。

进阶:尝试设计时间复杂度为 O(n)、空间复杂度为 O(1) 的算法解决此问题。

解法一:排序

多数元素在数组中至少占一半,因此将数组生序或者降序排列,中间位置的元素一定是多数元素。

ini 复制代码
function majorityElement(nums: number[]): number {
    const sortedNums:number[] = []
    const len = nums.length
    for (let i = 0; i < len; i++) {
        let insertIndex = 0;
        while(insertIndex <= sortNums.length) {
            if (insertIndex === sortedNums.length || sortedNums[insertIndex] > nums[i] ) {
                sortedNums.splice(insertIndex,0, nums[i])
                break
            }
            insertIndex++
        }
    }
    const m = Math.floor(sortedNums.length / 2)
    return sortedNums[m]
};

有嵌套循环因此时间复杂度为 O(n * n),有额外的中间量存储空间,空间复杂度为 O(n)

解法二:hash 表

用一个 map 统计数组中元素出现的次数,key 为 数组中的元素,value 为元素出现的次数,统计结束,判断哪个元素出现的次数大于 ⌊ n/2 ⌋,满足要求的元素是多数元素。

typescript 复制代码
function majorityElement(nums: number[]): number {
  const countMap = new Map<number,number>()
  nums.forEach(num => {
    const curCount = countMap.get(num) || 0
    countMap.set(num,curCount + 1)
  })

  const maxCount = Math.round(nums.length / 2)
  for (const [number, count] of countMap) {
    if (count >= maxCount) {
      return number
    }
  }
}

countMap.size 的最大值为 n/2,两次遍历的时间复杂度为 O (n + n/2) => O ( 2 * n), 有额外的中间量存储空间,空间复杂度为 O(n)

解法三:摩尔投票法

假设,数组中的元素是人,相同元素属于相同的团,元素的数量是团的人数,让不同团的两两决战,每人只能决战一次,决战之后离开团,这些团剩下的人就是多数元素.

ini 复制代码
function majorityElement(nums: number[]):number {
  let majority
  let count = 0

  nums.forEach(num => {
    if (count === 0) {
      majority = num
    }

    if (num === majority) {
      count ++
    }

    if (num !== majority) {
      count --
    }
  })

  return majority
}

时间复杂度O(n),空间复杂度 O(1)

相关推荐
2401_89207098几秒前
算法与数据结构精讲:最大子段和(暴力 / 优化 / 分治)+ 线段树从入门到实战
c++·算法·线段树·最大子段和
memcpy03 分钟前
LeetCode 904. 水果成篮【不定长滑窗+哈希表】1516
算法·leetcode·散列表
Hilaku5 分钟前
OpenClaw 跟病毒的区别是什么?
前端·javascript·人工智能
jerrywus5 分钟前
AI 写代码总翻车?我用 Harness:developer 把它管成“右侧打工人”
前端·agent·claude
老四啊laosi12 分钟前
[双指针] 8. 四数之和
算法·leetcode·四数之和
汀、人工智能13 分钟前
[特殊字符] 第24课:反转链表
数据结构·算法·链表·数据库架构··反转链表
田梓燊18 分钟前
leetcode 41
数据结构·算法·leetcode
_深海凉_29 分钟前
LeetCode热题100-三数之和
算法·leetcode·职场和发展
y = xⁿ43 分钟前
【LeetCode】双指针合集
算法·leetcode
2601_949539451 小时前
家用新能源 SUV 核心技术科普:后排娱乐、空间工程与混动可靠性解析
大数据·网络·人工智能·算法·机器学习