力扣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)将所有元素进行异或,最后的结果是只出现一次的元素。

相关推荐
振鹏Dong2 分钟前
字符串——面试考察高频算法题
java·数据结构·算法
longlong int40 分钟前
【每日算法】Day 17-1:位图(Bitmap)——十亿级数据去重与快速检索的终极方案(C++实现)
开发语言·c++·算法
泛舟起晶浪1 小时前
大衣的旅行--前缀和+二分
数据结构·算法
Run_Teenage1 小时前
C语言 数据结构【双向链表】动态模拟实现
c语言·数据结构·链表
歪~~2 小时前
KMP算法
数据结构·c++·算法
梁下轻语的秋缘3 小时前
每日c/c++题 备战蓝桥杯(小球反弹)[运动分解求解,最大公约数gcd]
c语言·c++·学习·算法·数学建模·蓝桥杯
SiMmming3 小时前
【算法竞赛】状态压缩型背包问题经典应用(蓝桥杯2019A4分糖果)
c++·经验分享·算法·职场和发展·蓝桥杯·动态规划
DexterYttt3 小时前
AT_abc212_d [ABC212D] Querying Multiset
数据结构·c++·算法·优先队列
刻意思考3 小时前
KM算法的时间复杂度,为什么可以降低一个数量级
后端·算法·程序员
橙序员小站3 小时前
探究分布式哈希算法:哈希取模与一致性哈希
算法·架构