leetcode面试题17.04:消失的数字(C语言版)

思路1

先排序,再依次查找,如果下一个值不等于前一个+1,那么下一个值就是消失数字。

时间复杂度分析:冒泡排序的时间复杂度为O(N^2),qsort排序时间复杂度为O(N*logN)。因此该思路不可行。


思路2

求和0到N,再减去数组中求和的值。

时间复杂度分析:两次循环,结果为O(N)。因此该思路可行,但有内存溢出风险。(这边可以通过等差数列求和公式求和,这样只需要一次循环,速度更快)


思路3

通过异或操作符号,相同的值为0,不相同的值为1;因为有 a^a = 0 已经 0^a = a 这两条性质,第一次遍历循环把数组全部的元素异或,第二次遍历循环再把numSize大小的元素异或,那么就可以找到只出现了一次的数字,即为消失的数字。(可以通过下图辅助理解)

时间复杂度:两次次循环,结果为O(N)。因此该思路可行,同时没有溢出风险,是最优解。

思路2的代码:

cpp 复制代码
int missingNumber(int* nums, int numsSize){
    int sum=0,i=0,cmp=0;
    for(i=0;i<numsSize;i++)
        sum+=nums[i];
    for(i=0;i<=numsSize;i++)
        cmp+=i;
    return cmp-sum;
}

思路3的代码:

cpp 复制代码
int missingNumber(int* nums, int numsSize){
    int N=numsSize;
    int x=0;
    for(int i=0;i<numsSize;i++)
    {
        x^=nums[i];
    }
    for(int j=0;j<=N;j++)
    {
        x^=j;
    }
    return x;
}
相关推荐
练习时长一年38 分钟前
LeetCode热题100(搜索插入位置)
数据结构·算法·leetcode
(●—●)橘子……1 小时前
记力扣557.反转字符串中的单词 练习理解
算法·leetcode·职场和发展
sprintzer2 小时前
12.06-12.15力扣分治法刷题
算法·leetcode
月明长歌2 小时前
【码道初阶】【牛客BM30】二叉搜索树与双向链表:java中以引用代指针操作的艺术与陷阱
java·数据结构·算法·leetcode·二叉树·笔试·字节跳动
刃神太酷啦2 小时前
Linux 进程核心原理精讲:从体系结构到实战操作(含 fork / 状态 / 优先级)----《Hello Linux!》(6)
java·linux·运维·c语言·c++·算法·leetcode
小李小李快乐不已2 小时前
数组&&矩阵理论基础
数据结构·c++·线性代数·算法·leetcode·矩阵
SiYuanFeng3 小时前
新手leetcode快速刷题指南
算法·leetcode·职场和发展
长安er3 小时前
LeetCode 77/216/22组合型回溯法-组合 / 组合总和 III / 括号生成)
数据结构·算法·leetcode·剪枝·回溯
菜鸟233号3 小时前
力扣98 验证二叉搜索树 java实现
java·数据结构·算法·leetcode
循着风4 小时前
环形子数组的最大和
数据结构·算法·leetcode