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]
    }
}
相关推荐
qq_513970447 小时前
力扣 hot100 Day37
算法·leetcode
不見星空8 小时前
leetcode 每日一题 1865. 找出和为指定值的下标对
算法·leetcode
杂雾无尘8 小时前
开发者必看,全面解析应用更新策略,让用户无法拒绝你的应用更新!
ios·xcode·swift
chao_78911 小时前
回溯题解——子集【LeetCode】二进制枚举法
开发语言·数据结构·python·算法·leetcode
GEEK零零七11 小时前
Leetcode 1070. 产品销售分析 III
sql·算法·leetcode
凌肖战11 小时前
力扣网编程274题:H指数之普通解法(中等)
算法·leetcode
帅次12 小时前
【iOS设计模式】深入理解MVC架构 - 重构你的第一个App
ios·swiftui·objective-c·iphone·swift·safari·cocoapods
Y1nhl14 小时前
力扣_链表_python版本
开发语言·python·算法·leetcode·链表·职场和发展
东坡肘子16 小时前
高温与奇怪的天象 | 肘子的 Swift 周报 #092
人工智能·swiftui·swift
Swift社区17 小时前
Swift 解 LeetCode 320:一行单词有多少种缩写可能?用回溯找全解
开发语言·leetcode·swift