leetcode刷题:消失的数字

这篇具有很好参考价值的文章主要介绍了leetcode刷题:消失的数字。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

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

注意:本题相对书上原题稍作改动

示例 1:

输入:[3,0,1]
输出:2

示例 2:

输入:[9,6,4,2,3,5,7,0,1]
输出:8

针对于这道题,我们提供了三种解法:

一、排序法遍历法

首先使用快排对数组进行排序,使其变成有序数组,由题意得知,在0~n的所有整数连续存放那的数组中前一个数字加一就是下一个数字的值,所以我们可以以这个为判断条件,遍历数组,当碰到不符合该条件的值时,直接跳出循环,我们就可以找出缺失的值是该下标对应值+1

int cmp(const int* e1 , const int* e2)
{
    return *e1 - *e2;
}
int missingNumber(int* nums, int numsSize){
    qsort(nums , numsSize , sizeof(int) , cmp);//1
    if(nums[0] != 0)
        return 0;
    int i = 0 ;
    while(i < numsSize && i+1 < numsSize)
    {
        if(nums[i+1] == nums[i] + 1)
        {
            i++;
        }
        else
        {
            break;
        }
    }
    return nums[i]+1;
}

要注意的是,当数组为{1}时,需要特殊判断一下,因为此时不会进入判断条件,直接执行最后一句话,造成错误。

二、 计算总和法

思路:由题意,我们得知,假设一个是有n个数的数组,包含0~n的所有整数,其中缺失了一个,所以它必定多出了一个数字,因为数组的大小是固定的。所以我们利用循环,把0~(n+1)个数字累加到sum上,再让sum依次减去这个数组内的全部值,最终可以得到缺失的数字。

int missingNumber(int* nums, int numsSize){
    //采用相减的方法
    int i = 0;
    int sum = 0;
    for(i=0;i<=numsSize;i++)
    {
        sum += i;
    }
    for(i = 0 ;i<numsSize ;i++)
    {
        sum -= nums[i];
    }
    return sum;
}

三、按位异或法 

通过对于“按位异或”操作符的理解我们知道:a^a= 0 ,  a^0 =a    ,a^b^b=a^0 = a.

对于按位异或操作符不理解的可以看一下下面的博客:操作符详解(这么详细的操作符介绍你确定不看一看?)【C语言】【附试题详解】-CSDN博客

通过0按位异或一个数两次最终会得到0,我们可以进行以下设计:定义一个临时变量sum,让sum依次抑或0~(n+1)的值,然后再分别抑或这个缺失了数字的数组,最终的sum即为缺失的数字。文章来源地址https://www.toymoban.com/news/detail-820679.html

//采用位运算
//a^b^b = a
int missingNumber(int* nums, int numsSize){
    int i = 0 , sum =0;
    for(int i = 0; i <= numsSize ; i++)
    {
        sum ^= i;
    }
    for(i =0 ; i < numsSize ;i++)
    {
        sum ^= nums[i];
    }
    return sum ;
}

到了这里,关于leetcode刷题:消失的数字的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Leetcode刷题---C语言实现初阶数据结构---单链表

    删除链表中等于给定值 val 的所有节点 给你一个链表的头节点head和一个整数val,请你删除链表中所有满足Node.val==val的节点,并返回新的头节点 输入:head = [1,2,6,3,4,5,6], val = 6 输出:[1,2,3,4,5] 示例 2: 输入:head = [ ], val = 1 输出:[ ] 示例 3: 输入:head = [7,7,7,7], val = 7 输出:

    2024年02月15日
    浏览(56)
  • java数据结构与算法刷题-----LeetCode283. 移动零

    java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完): https://blog.csdn.net/grd_java/article/details/123063846 解题思路 双指针,用right和left两个指针,将非0元素,全部按顺序换到数组前面。left指向左边非0元素应该插入的位置,right找到非

    2024年01月21日
    浏览(49)
  • java数据结构与算法刷题-----LeetCode566. 重塑矩阵

    java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完): https://blog.csdn.net/grd_java/article/details/123063846 代码:时间复杂度O(r*c).除题目要求外,算法本身没有需要额外空间,空间复杂度O(1) 从0开始算,一个3列n行矩阵中,每行就有3个元

    2024年01月21日
    浏览(46)
  • 【刷题】面试题 17.04. 消失的数字

    面试题 17.04. 消失的数字 数组nums包含从0到n的所有整数,但其中缺了一个。请编写代码找出那个缺失的整数。你有办法在O(n)时间内完成吗? 输入:[3,0,1] 输出:2 输入:[9,6,4,2,3,5,7,0,1] 输出:8 排序,依次查找,如果下一个数不是上一个数加1,则上一个数加1就是消失的数字。

    2023年04月18日
    浏览(41)
  • java数据结构与算法刷题-----LeetCode287. 寻找重复数

    java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完): https://blog.csdn.net/grd_java/article/details/123063846 解题思路 弗洛伊德判圈法,也就是快慢指针判圈法(龟兔赛跑算法),此算法分为两个步骤 判断是否有环,并得到快慢指针相遇

    2024年01月24日
    浏览(43)
  • java数据结构与算法刷题-----LeetCode766. 托普利茨矩阵

    java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完): https://blog.csdn.net/grd_java/article/details/123063846 解题思路 这道题只要换一种理解方式,瞬间就会变的很简单。 题目描述是每个元素左上和右下对角线元素都相同。但是,我们发

    2024年01月25日
    浏览(48)
  • java数据结构与算法刷题-----LeetCode667. 优美的排列 II

    java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完): https://blog.csdn.net/grd_java/article/details/123063846 解题思路 题目要求我们返回一个数组长度为n的数组,必须含有1~n的所有数,并且从左到右,相邻的元素依次相减,它们的差,必

    2024年01月25日
    浏览(52)
  • java数据结构与算法刷题-----LeetCode240. 搜索二维矩阵 II

    java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完): https://blog.csdn.net/grd_java/article/details/123063846 解题思路 法一:把整个数组遍历一遍,时间复杂度O(m*n) 法二:每一行用二分搜索,那么时间复杂度就是O(m * l o g 2 n log_2{n} l o g

    2024年01月22日
    浏览(61)
  • java数据结构与算法刷题-----LeetCode209. 长度最小的子数组

    java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完): https://blog.csdn.net/grd_java/article/details/123063846 解题思路 代码:时间复杂度O(n).空间复杂度O(1)

    2024年01月21日
    浏览(54)
  • java数据结构与算法刷题-----LeetCode96. 不同的二叉搜索树

    java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完): https://blog.csdn.net/grd_java/article/details/123063846 很多人觉得动态规划很难,但它就是固定套路而已。其实动态规划只不过是将多余的步骤,提前放到dp数组中(就是一个数组,只

    2024年01月21日
    浏览(56)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包