当前位置: 首页> 科技> 数码 > 169. 多数元素

169. 多数元素

时间:2025/7/10 10:26:39来源:https://blog.csdn.net/qfeung/article/details/139281707 浏览次数:2次

题目

在这里插入图片描述

解答

方法一:Boyer-Moore 投票算法
class Solution {func majorityElement(_ nums: [Int]) -> Int {var candidate = 0var count = 0for num in nums {if count == 0 {candidate = numcount += 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 开始)一定是众数。

class Solution {func majorityElement(_ nums: [Int]) -> Int {// 如果数组中的元素是整形,字符串,结构体等简单数据类型,那么当你将一个数组赋值给另外的数组时,数组中的元素会被拷贝一份,两个数组中的元素相互独立var numbers = numsnumbers.sort(by: >)return numbers[nums.count / 2]}
}

在这里插入图片描述

关键字:169. 多数元素

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: