LeetCode 136 Single Number 只出现一次的数字 中英对照

本文解析了LeetCode上的单数查找问题,介绍了两种解法:一种是哈希表方法,但空间复杂度较高;另一种是巧妙利用异或运算,实现线性时间复杂度和常量空间。通过代码实例展示了如何利用异或运算快速找到数组中那个仅出现一次的数字。
摘要由CSDN通过智能技术生成

题目来源:力扣(LeetCode)
题目链接:https://leetcode.cn/problems/single-number

题目

Given a non-empty array of integers nums, every element appears twice except for one. Find that single one.
给定一个非空整数数组(a array of 可以理解为形容词”一系列的“,这里的 a array of integers nums 不是这样的用法,是整数的一个数组,array 大堆、数组、阵列、布置排列),除了某个元素只出现一次以外,其余每个元素均出现两次(直译是,每个元素都出现了两次,除了一个之外)。找出那个只出现了一次的元素。

You must implement a solution with a linear runtime complexity and use only constant extra space.
你的算法应该具有线性时间复杂度,并且使用常熟的额外空间。(constant 常熟、常量、恒定的,linear 线性,linen 亚麻布、亚麻织品,complexity 复杂度,complexible 复杂的,extra 额外的、另外的,space 空间、间隙,implement 实现、执行、工具、器具)

题解

解法一 哈希

接近常数时间,但是空间复杂度 O(n),而且时间复杂度不稳定,取决于数据情况,如果哈希函数不够好,可以造数据让你的哈希时间复杂度很高。

not recommended

解法二 巧用异或运算

异或运算在很多地方都有妙用,在 ALU 加法器中,可以用在穿行进位中的本位和表达式、进位表达式,并行进位中的进位传递函数,硬布线控制单元的微操作命令设计,以及电路优化。(不知道没关系,只是联动一下)。

异或运算理解为不进位加法即可,非常好记。

本题利用异或运算的特性:

  • 对同一个数异或两次,相当于没有改变,即对一个数异或第二次时会变成原来的数。(用的这一条)
  • 任何一个偶数,和他下一个数(偶数 + 1)异或结果为 1

代码

class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int res = 0;
        for (int i = 0; i < nums.size(); ++ i) {
            res ^= nums[i];
        }
        return res;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

肥羊也

感谢给肥羊投喂!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值