【数据结构系列01】时间复杂度和空间复杂度:消失的数字

面试题 17.04. 消失的数字 - 力扣(LeetCode)

思路1:

先排序,再依次比较后一个是否比前一个大1

时间复杂度:O(nlogn)

思路2:

求和0-n,再依次减去数组中的值,剩下的那个值就是消失的数字

时间复杂度:O(n)

缺点:N太大时会存在溢出风险

思路3:最佳

异或:相同的值异或后==0

cpp 复制代码
int missingNumber(int* nums, int numsSize) {
    //采用异或的方法
    int sum=0;//采用0的原因,异或是相同为0,不同为1,任意数与0异或都是任意数
    for(int i = 0; i < numsSize; i++)
    {
        sum ^= nums[i];
    }
    for(int i = 0; i <= numsSize ; i++)
    {
        sum ^= i;
    }
    return sum;
}

总结

本文通过 消失的数字 这道经典题目,深入分析了不同解法的时间复杂度

思路 方法 时间复杂度 空间复杂度 优缺点
思路1 排序 + 遍历 O(n log n) O(1) 简单直观,但效率较低
思路2 求和相减 O(n) O(1) 线性时间,但存在溢出风险
思路3 异或运算 O(n) O(1) 最优解,无溢出,效率高

可以看出,同一个问题,不同的算法设计会带来完全不同的效率表现。掌握复杂度分析,能帮助我们在实际开发中选择最合适的解法。

核心收获:

  • ✅ 时间复杂度不是算具体时间,而是看操作次数随数据规模的增长趋势

  • ✅ 大O渐进表示法关注量级而非细节

  • ✅ 异或运算(^)是一个非常有用的位运算技巧:a ^ a = 0,a ^ 0 = a


下期预告

下一期我们将继续 【数据结构系列02】,一起来看另一道经典题目:

【旋转数组】:如何用 O(1) 的额外空间实现数组的右移?

如果你对时间复杂度还有疑问,欢迎在评论区留言讨论!如果觉得有帮助,别忘了点赞 + 收藏 + 关注,我们下期见!🚀


💡 小贴士:复杂度分析是数据结构的基石,建议你自己动手把上面三种思路的代码都跑一遍,感受一下不同算法的差异!

相关推荐
Trouvaille ~12 分钟前
零基础入门 LangChain 与 LangGraph(五):核心组件上篇——消息、提示词模板、少样本与输出解析
人工智能·算法·langchain·prompt·输入输出·ai应用·langgraph
MOON404☾30 分钟前
Chapter 002. 线性回归
算法·回归·线性回归
故事和你911 小时前
洛谷-数据结构-1-3-集合3
数据结构·c++·算法·leetcode·贪心算法·动态规划·图论
春栀怡铃声1 小时前
【C++修仙录02】筑基篇:类和对象(上)
开发语言·c++·算法
自我意识的多元宇宙1 小时前
二叉树的遍历和线索二叉树--线索二叉树
数据结构
ulias2121 小时前
leetcode热题 - 3
c++·算法·leetcode·职场和发展
实心儿儿1 小时前
Linux —— 进程概念 - 程序地址空间
linux·运维·算法
菜鸟丁小真1 小时前
LeetCode hot100-287.寻找重复数和994.腐烂的橘子
数据结构·算法·leetcode·知识点总结
发发就是发2 小时前
USB系统架构概述:从一次诡异的枚举失败说起
驱动开发·单片机·嵌入式硬件·算法·fpga开发
笨鸟先飞的橘猫2 小时前
数据结构学习——跳表
数据结构·python·学习