码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • C语言练习之消失的数字(两种解法)


    目录

    前言

    一、思路

    思路一(异或法)

    思路二(求和法)

    二、代码

    代码1

    代码2

    总结


    前言

    题目描述:

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

    测试举例:

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

    一、思路

    思路一(异或法)

    首先要明白什么是异或(异或就是二进制位的数值,相等则为0,不相等则为1)

    假设a!=b,则有以下公式:

    a^a = 0;

    a^b = b^a;

    0^a = a;

    根据公式可以想到:

    先将0~n的所有数字全部异或

    ret1 = 0^1^……^n;

    再将数组(缺失数字)中的数全部异或

    ret2 = nums[0]^nums[2]^……^nums[numsSize-1];

    最后将ret1和ret2异或,所得结果就是缺失的数字。

    思路二(求和法)

    由观察可知,缺少的数字等于0~n数字之和减去0~n除了所缺少数字外其他数字之和。

    二、代码

    为了方便大家的交流和学习,我将函数的代码放置在下方。

    代码1

    1. int missingNumber(int* nums, int numsSize){
    2. int i = 0;
    3. int sum1 = 0,sum2 = 0;
    4. for(i = 0;i < numsSize +1; i++)//0~n个整数之和
    5. {
    6. sum1 += i;
    7. }
    8. for(i = 0; i < numsSize ;i++)//所给数组的元素之和
    9. {
    10. sum2 += nums[i];
    11. }
    12. return sum1 - sum2;
    13. }

    代码2

    1. int missingNumber(int* nums, int numsSize){
    2. int i = 0;
    3. int ret1 = 0,ret2 = 0;
    4. for(i = 0;i < numsSize +1; i++)//0~n所有整数的异或
    5. {
    6. ret1 ^= i;
    7. }
    8. for(i = 0; i < numsSize ;i++)//所给数组的所有元素的异或
    9. {
    10. ret2 ^= nums[i];
    11. }
    12. return ret1^ret2;
    13. }

    总结

    以上就是今天要讲的内容,本文简单的介绍了如何用C语言解决消失的数字这个题的思路。

    这个题是我在做题时遇到的一道觉得很有意思的题,对我的做题思路有很大的启发作用,所以将它分享给大家。

    如果本篇文章对你有所启发的话,希望可以支持支持作者,后续作者也会定期更新学习记录。谢谢大家!

  • 相关阅读:
    springboot整合Redis后间歇性io.lettuce.core.RedisCommandTimeoutException
    如何将多个PDF文件合并一步完成?
    应用密码学期末速通复习
    大数据组件系列-Hadoop每日小问
    Redis常用命令
    第4章 前馈神经网络
    【Java UI】HarmonyOS 如何集成SlidingDrawer组件
    chatGLM-Windows环境安装
    首批48所高校大模型开课“尝鲜”,AI教学赋能计划合作名单公布
    又一个新项目完结,炸裂!
  • 原文地址:https://blog.csdn.net/xjjxjy_2021/article/details/127929967
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号