备战秋招60天算法挑战,Day22

题目链接: https://leetcode.cn/problems/missing-number/

视频题解: https://www.bilibili.com/video/BV1HS42197Hc/

LeetCode 268.丢失的数字

题目描述

给定一个包含 [0, n]n 个数的数组 nums ,找出 [0, n] 这个范围内没有出现在数组中的那个数。

举个例子:

复制代码
输入:nums = [3,0,1]
输出:2
解释:n = 3,因为有 3 个数字,所以所有的数字都在范围 [0,3] 内。2 是丢失的数字,因为它没有出现在 nums 中。

视频题解

丢失的数字

思路来源

思路来源

思路解析

方法一 位运算

首先来看一下异或运算的特点,11转成二进制101113转成二进制1101,它们之间的异或运算如下图:

11 ^ 13 = 611 ^ 11 = 0,可以看出,对于二进制相同的bit位按位异或值是0,比如1 ^ 1 = 00 ^ 0 = 0。不同值bit位按位异或值是1,比如1 ^ 0 = 1

利用异或运算符这个特性我们可以轻松解决这个题目。

对区间[0, n]和数组nums中所有的元素做异或运算,在nums中的元素会出现两次,不在nums中的元素只会出现一次,两个相同的元素做异或值为0,最后的结果就是不在nums中的元素。

比如n = 3nums = [3, 0, 1]0 ^ 1 ^ 2 ^ 3 ^ 3 ^ 0 ^ 1 = (0 ^ 0) ^ (1 ^ 1) ^ (3 ^ 3) ^ 2 = 0 ^ 2 = 2。最终2就是不在nums中的数字。

C++代码

cpp 复制代码
class Solution {
public:
    int missingNumber(vector<int>& nums) {
        int nums_len = nums.size();
        int res = nums_len;
        for (int i = 0; i < nums_len; ++i) {
            //[0,n]和nums中的元素做异或操作
            res ^= (i ^ nums[i]); 
        }
        return res;
    }
};

java代码

java 复制代码
class Solution {
    public int missingNumber(int[] nums) {
        int nums_len = nums.length;
        int res = nums_len;
        for (int i = 0; i < nums_len; ++i) {
            //[0,n]和nums中的元素做异或操作
            res ^= (i ^ nums[i]);
        }
        return res;
    }
}

python 代码

python 复制代码
class Solution:
    def missingNumber(self, nums: List[int]) -> int:
        nums_len = len(nums)
        res = nums_len
        for i in range(nums_len):
            #[0,n]和nums中的元素做异或操作
            res ^= (i ^ nums[i])
        return res

方法二 数学运算

因为区间[0, n]上有n + 1个元素,数组nums中只有n个元素,假设缺失的元素为X,我们可以得到如下公式:

复制代码
0 + 1 +...+ n = nums[0] + nums[1] +...+ nums[n-1] + X 

我们只需要用区间[0, n]所有元素的和减去nums中所有元素的和就得到最终的结果X

C++代码

cpp 复制代码
class Solution {
public:
    int missingNumber(vector<int>& nums) {
        int nums_len = nums.size();
        int res = nums_len;
        for (int i = 0; i < nums_len; ++i) {
            //[0,n]的和减去nums中所有元素的和
            res += (i - nums[i]); 
        }
        return res;
    }
};

java代码

java 复制代码
class Solution {
    public int missingNumber(int[] nums) {
        int nums_len = nums.length;
        int res = nums_len;
        for (int i = 0; i < nums_len; ++i) {
            //[0,n]的和减去nums中所有元素的和
            res += (i - nums[i]);
        }
        return res;
    }
}

python代码

python 复制代码
class Solution:
    def missingNumber(self, nums: List[int]) -> int:
        nums_len = len(nums)
        res = nums_len
        for i in range(nums_len):
            #[0,n]的和减去nums中所有元素的和
            res += (i - nums[i])
        return res

复杂度分析

时间复杂度: 两种方法的整个过程都是只遍历了一遍数组,所以时间复杂度为O(n)n为数组nums的长度。

空间复杂度: 两种方法都只使用了几个整型变量,所以空间复杂度都是O(1)

相关推荐
听情歌落俗6 分钟前
MATLAB3-1变量-台大郭彦甫
开发语言·笔记·算法·matlab·矩阵
Propeller13 分钟前
【Android】View 交互的事件处理机制
android·java
量子炒饭大师16 分钟前
收集飞花令碎片——C语言关键字typedef
c语言·c++·算法
杨杨杨大侠17 分钟前
Atlas Mapper 教程系列 (5/10):集合映射与嵌套对象处理
java·开源·github
ERP老兵_冷溪虎山18 分钟前
Python/JS/Go/Java同步学习(第十三篇)四语言“字符串转码解码“对照表: 财务“小南“纸式转码术处理凭证乱码崩溃(附源码/截图/参数表/避坑指南)
java·后端·python
是2的10次方啊18 分钟前
如何设计10万QPS秒杀系统?缓存+消息队列+分布式锁架构实战
java
心灵宝贝19 分钟前
Tomcat Connectors 1.2.37 源码编译安装教程(mod_jk 详细步骤)
java·tomcat
澡点睡觉20 分钟前
【数据结构与算法Trip第4站】摩尔投票法
算法
杨杨杨大侠22 分钟前
Atlas Mapper 教程系列 (6/10):Spring Boot 集成与自动配置
java·开源·github
傻傻虎虎32 分钟前
【Docker】容器端口暴露+镜像生成实战
java·docker·容器