携手创造,一起成长!这是我参与「日新方案 8 月更文应战」的第5天,点击查看活动详情

前言

本题为 LeetCode 前 100 高频题

咱们社区陆续会将顾毅(Netflix 增长黑客,《iOS 面试之道》作者,ACE 工作健身教练。)的 Swift 算法题题解收拾为文字版以方便咱们学习与阅读。

LeetCode 算法到目前咱们已经更新到 134 期,咱们会坚持更新时刻和进展(周一、周三、周五早上 9:00 发布),每期的内容不多,咱们期望咱们能够在上班路上阅读,长久积累会有很大提高。

不积跬步,无以致千里;不积小流,无以成江海,Swift社区 伴你前行。假如咱们有建议和定见欢迎在文末留言,咱们会极力满意咱们的需求。

难度水平:简单

1. 描绘

给定一个非空整数数组,除了某个元素只呈现一次以外,其余每个元素均呈现两次。找出那个只呈现了一次的元素。

阐明:

你的算法应该具有线性时刻复杂度。 你能够不运用额外空间来实现吗?

2. 示例

示例 1

输入: nums = [2,2,1]
输出: 1

示例 2

输入: nums = [4,1,2,1,2]
输出: 4

示例 3

输入: nums = [1]
输出: 1

约束条件:

  • 1 <= nums.length <= 3 * 10^4
  • -3 * 10^4 <= nums[i] <= 3 * 10^4
  • 数组中的每个元素呈现两次,除了一个元素只呈现一次。

3. 答案

class SingleNumber {
    func singleNumber(nums: [Int]) -> Int {
        var res = 0
        for num in nums {
            res ^= num
        }
        return res
    }
}
  • 主要思想:异或
  • 时刻复杂度: O(n)
  • 空间复杂度: O(1)

该算法题解的仓库:LeetCode-Swift

点击前往 LeetCode 操练

关于咱们

咱们是由 Swift 爱好者一起维护,咱们会分享以 Swift 实战、SwiftUI、Swift 基础为核心的技术内容,也收拾搜集优秀的学习资料。