力扣136. 只出现一次的数字

给你一个 非空 整数数组 nums ,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。
你必须设计并实现线性时间复杂度的算法来解决此问题,且该算法只使用常量额外空间。


示例 1 :

复制代码
输入:nums = [2,2,1]
输出:1

示例 2 :

复制代码
输入:nums = [4,1,2,1,2]
输出:4

示例 3 :

复制代码
输入:nums = [1]
输出:1

提示:

  • 1 <= nums.length <= 3 * 104
  • -3 * 104 <= nums[i] <= 3 * 104
  • 除了某个元素只出现一次以外,其余每个元素均出现两次。

代码:

cpp 复制代码
class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int res = 0;

        for(int i = 0; i < nums.size(); i++){
            res = res ^ nums[i];
        }

        return res;
    }
};

解题思路:

(1)可以count()函数进行求解,也可以100%通过,但时间较长。

(2)这里使用二进制异或运算的特性,任何数异或0等于本身。

(3)两个相同的数异或是0。

(4)将所有元素进行异或,最后的结果是只出现一次的元素。

相关推荐
~yY…s<#>10 分钟前
【刷题22】BFS解决最短路问题
数据结构·c++·算法·leetcode·宽度优先
青岛少儿编程-王老师37 分钟前
CCF编程能力等级认证GESP—C++5级—20241207
java·开发语言·数据结构·c++·算法·青少年编程
DC_BLOG1 小时前
数据结构绪论
java·数据结构·算法
<但凡.2 小时前
数据结构与算法之美:双向循环链表
c语言·数据结构·链表
Wils0nEdwards2 小时前
Leetcode 加一
java·算法·leetcode
xuchaoxin13752 小时前
三角矩阵和对称阵的压缩存储
算法·矩阵
youk1102 小时前
STM32 HAL库之SDIO例程 Micro SD卡 - 1
算法
power-辰南2 小时前
机器学习支持向量机(SVM)算法
人工智能·python·算法·机器学习·支持向量机
空雲.2 小时前
牛客周赛71(字符串,状压dp)
数据结构·算法
橘子遇见BUG2 小时前
算法日记48 day 图论(拓扑排序,dijkstra)
算法·图论