169. 多数元素

题目

解答

方法一:Boyer-Moore 投票算法
swift 复制代码
class Solution {
    func majorityElement(_ nums: [Int]) -> Int {
        var candidate = 0
        var count = 0
        for num in nums {
            if count == 0 {
                candidate = num
                count += 1
            } else {
                if candidate == num {
                    count += 1
                } else {
                    count -= 1
                }
            }
        }
        return candidate
    }
}

引申:Swift 的内置排序算法 sort() 在 Swift5 之后采用了 TimSort,相较于之前的 Introsort 更 stability,TimSort 是一种混合算法, 核心原理是 切割 + 合并, 时间复杂度是 O(nlogn)


方法二:排序

如果将数组 nums 中的所有元素按照单调递增或单调递减的顺序排序,那么下标为 n / 2 的元素(下标从 0 开始)一定是众数。

swift 复制代码
class Solution {
    func majorityElement(_ nums: [Int]) -> Int {
        // 如果数组中的元素是整形,字符串,结构体等简单数据类型,那么当你将一个数组赋值给另外的数组时,数组中的元素会被拷贝一份,两个数组中的元素相互独立
        var numbers = nums
        numbers.sort(by: >)
        return numbers[nums.count / 2]
    }
}
相关推荐
小羊在睡觉15 小时前
力扣239. 滑动窗口最大值
数据结构·后端·算法·leetcode·go
大大杰哥16 小时前
leetcode hot100(4)矩阵
算法·leetcode·矩阵
叶小鸡16 小时前
小鸡玩算法-力扣HOT100-动态规划(上)
算法·leetcode·动态规划
凌波粒17 小时前
LeetCode--513.找树左下角的值(二叉树)
java·算法·leetcode
Daniel_Coder18 小时前
iOS Widget 开发-18:Widget 的 SwiftUI 视图适配与设计
ios·swiftui·swift·widget·widgetcenter
Daniel_Coder18 小时前
iOS Widget 开发-17:Widget 错误处理与空状态设计
ios·swift·widget·widgetcenter
wjm04100618 小时前
简单谈谈ios开发中的UI
开发语言·ios·swift
一只小逸白19 小时前
LeetCode Go 常用函数速查表
linux·leetcode·golang
Tisfy19 小时前
LeetCode 3043.最长公共前缀的长度:哈希表(不转string)
算法·leetcode·散列表·题解·哈希表
承渊政道19 小时前
【贪心算法】(经典实战应用解析(六):整数替换、俄罗斯套娃信封问题、可被三整除的最⼤和、距离相等的条形码、重构字符串)
c++·算法·leetcode·贪心算法·排序算法·动态规划·哈希算法