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]
    }
}
相关推荐
Miraitowa_cheems1 天前
LeetCode算法日记 - Day 108: 01背包
数据结构·算法·leetcode·深度优先·动态规划
小武~1 天前
Leetcode 每日一题C 语言版 -- 88 merge sorted array
c语言·算法·leetcode
Swift社区1 天前
LeetCode 429 - N 叉树的层序遍历
算法·leetcode·职场和发展
非专业程序员1 天前
Swift 多线程读变量安全吗?
swiftui·swift
Sirius Wu1 天前
开源训练框架:MS-SWIFT详解
开发语言·人工智能·语言模型·开源·aigc·swift
从零开始学习人工智能1 天前
USDT区块链转账 vs SWIFT跨境转账:技术逻辑与场景博弈的深度拆解
开发语言·ssh·swift
无敌最俊朗@2 天前
力扣hot100-206反转链表
算法·leetcode·链表
Kuo-Teng2 天前
LeetCode 279: Perfect Squares
java·数据结构·算法·leetcode·职场和发展
RickeyBoy2 天前
Swift6 @retroactive:Swift 的重复协议遵循陷阱
swiftui·swift
CoderYanger2 天前
B.双指针——3194. 最小元素和最大元素的最小平均值
java·开发语言·数据结构·算法·leetcode·职场和发展·1024程序员节