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]
    }
}
相关推荐
大熊猫侯佩19 分钟前
冰火岛 Tech 传:Apple Foundation Models 心法解密(上集)
llm·ai编程·swift
HarderCoder22 分钟前
深入理解 SwiftUI 的 Structural Identity:为什么“换个条件分支”就会丢状态?
swiftui·swift
HarderCoder31 分钟前
Swift Continuations 完全指南:一口气弄懂 4 种“桥梁”
swift
HarderCoder2 小时前
Swift 的 `withoutActuallyEscaping`:借一个 `@escaping` 身份,但不真的逃跑
swift
Swift社区2 小时前
Swift 解法详解:LeetCode 371《两整数之和》
开发语言·leetcode·swift
Swift社区2 小时前
Swift 解法详解 LeetCode 362:敲击计数器,让数据统计更高效
开发语言·leetcode·swift
HarderCoder3 小时前
Opaque Types 完全指南:Swift 的“密封盒子”魔法
swift
HarderCoder4 小时前
Thread.sleep vs Task.sleep:一句话记住“别再阻塞线程”
swift
小刘的AI小站5 小时前
leetcode hot100 二叉搜索树
算法·leetcode
自信的小螺丝钉5 小时前
Leetcode 876. 链表的中间结点 快慢指针
算法·leetcode·链表·指针