当前位置: 首页 > news >正文

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

4e0949b7eb2d4b8ba5c00ab61d5eb971.png

思路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)。因此该思路可行,同时没有溢出风险,是最优解。

0d65831c5483453ea4da2177595d0be7.png

思路2的代码:

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;
}

ea7cf8603fdb457c94db050e6421e810.png

思路3的代码:

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;
}

5b926df0f0eb4843b6a0ac3254af6569.png


http://www.mrgr.cn/news/43499.html

相关文章:

  • Gitlab flow工作流
  • linux—进程控制
  • 【信息系统项目管理师 考题预测】采购管理
  • Linux多线程
  • 【在Linux世界中追寻伟大的One Piece】进程信号
  • 【微服务】服务注册与发现、分布式配置管理 - Nacos
  • 智谱AI开源CogView3及升级版,文生图技术新突破!
  • java 数据存储方式
  • 有关自连接表的统一封装
  • Ray_Tracing_The_Next_Week下
  • 基于Pcap4j收发自定义协议报文(注意事项/踩坑总结)
  • 算法篇1:双指针思想的运用(1)--C++
  • Gitee创建仓库,提交代码到自己的fork,合并到主分支
  • No.4 笔记 | 探索网络安全:揭开Web世界的隐秘防线
  • 【可视化大屏】将柱状图引入到html页面中
  • C++ 异步编程 并发编程技术
  • C语言入门基础题(力扣):完成旅途的最少时间(C语言版)
  • CGLib动态代理和JDK动态代理Demo、ASM技术尝鲜
  • AbMole牛磺胆酸钠在构建大鼠急性胰腺炎模型中的应用
  • 环境可靠性