leetcode17.04面试题:消失的数字

数组nums包含从0n的所有整数,但其中缺了一个。请编写代码找出那个缺失的整数。你有办法在O(n)时间内完成吗?

思路1:暴力枚举

定义一个[0~n]的数组与所给数组nums进行循环遍历,如果不相等则返回那个数。

cpp 复制代码
int missingNumber(int* nums, int numsSize){
    int sz=numsSize+1;
    int arr[sz];
    for(int i=0;i<sz;i++){
        arr[i]=i;
    }
    for(int i=0;i<sz;i++){
        int count=0;
        for(int j=0;j<numsSize;j++){
            if(arr[i]==nums[j]){
                count++;
            }
        }
        if(count==0){
            return arr[i];
       }
        
    }
    return 0;
}

思路二:求和相减

只需要将原本的数求和,与所给的数组求和,相减就可以得到缺失的那个数

cpp 复制代码
int missingNumber(int* nums, int numsSize){
    int my_total=((0+numsSize)*(numsSize+1))/2;
    int nums_total=0;
    
    for(int i=0;i<numsSize;i++){
        nums_total+=nums[i];
    }
    return my_total-nums_total;
}

思路三:按位异或

根据按位异或原则,相同为0,不同为1,0与任何数异或为它本身。例如1 1 3 2 4 3 4 从第一个1异或到最后一个数4,相同的就没了,只剩一个数2。那么我们就可以按照这种思路,定义一个初始值为0的变量,先与我的数组进行异或,再与给定数组进行异或,我的数组里如果含有给定数组的里数那么就异或掉,最后异或出一个没有的数。

cpp 复制代码
int missingNumber(int* nums, int numsSize){
    int x=0;
    int i=0;
    for(i=0;i<=numsSize;++i){
        x^=i;
    }
    for(i=0;i<numsSize;++i){
        x^=nums[i];
    }
    return x;
}
相关推荐
好奇龙猫4 分钟前
【学习AI-相关路程-mnist手写数字分类-win-硬件:windows-自我学习AI-实验步骤-全连接神经网络(BPnetwork)-操作流程(3) 】
人工智能·算法
sp_fyf_202440 分钟前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-11-01
人工智能·深度学习·神经网络·算法·机器学习·语言模型·数据挖掘
香菜大丸1 小时前
链表的归并排序
数据结构·算法·链表
jrrz08281 小时前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
oliveira-time1 小时前
golang学习2
算法
南宫生2 小时前
贪心算法习题其四【力扣】【算法学习day.21】
学习·算法·leetcode·链表·贪心算法
懒惰才能让科技进步3 小时前
从零学习大模型(十二)-----基于梯度的重要性剪枝(Gradient-based Pruning)
人工智能·深度学习·学习·算法·chatgpt·transformer·剪枝
Ni-Guvara3 小时前
函数对象笔记
c++·算法
泉崎3 小时前
11.7比赛总结
数据结构·算法
你好helloworld3 小时前
滑动窗口最大值
数据结构·算法·leetcode