码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【算法】位运算算法——消失的两个数字(困难)


    题解:消失的两个数字(位运算算法)

    目录

    • 1.题目
    • 2.题解
    • 3.示例代码如下
    • 4.总结

    1.题目

    题目链接:LINK
    在这里插入图片描述

    2.题解

    本题要求时间复杂度O(N),空间复杂度O(1),分别否了我们 排序遍历 和 哈希数组 的想法。想要在规定时间/空间复杂度内完成本题,需要借用 位运算算法。

    具体该如何操作呢?
    ①首先,我们将 原数组 与 [1,n+2] 的数字全部 异或起来,这时候会得出 ret = a ^ b
    ②根据ret,我们可以知道 a 与 b 的不同的一位二进制,我们根据这位不同的二进制来区分a 和 b
    ③让 原数组 和 [1,n+2] 数字根据不同的这一二进制位 站队,再把两队全部异或起来消去相同的一项得出a 和 b,因为a 和 b只在[1,n+2]中出现过一次因而不会被异或掉。

    可能单纯叙述有点抽象,我直接用一个例子来说明我上面说的步骤:


    在这里插入图片描述


    在这里插入图片描述


    在这里插入图片描述


    在这里插入图片描述


    在这里插入图片描述


    3.示例代码如下

    class Solution {
    public:
        vector<int> missingTwo(vector<int>& nums) 
        {
            int ret = 0;
            for(auto& num : nums) ret ^= num;
            for(int i = 1; i <= nums.size()+2; i++) ret ^= i; 
            
            //ret = a ^ b
            int count = 0;
    
            while(1)
            {
                if(((ret >> count) & 1) == 1) break;
                else count++;
            }
            
            int a = 0;
            int b = 0;
            for(auto& num: nums) 
            {
                if(((num >> count) & 1) == 1) a ^= num;
                else b^=num;
            }
            for(int i = 0; i <= nums.size()+2; i++)
            {
                if(((i >> count) & 1) == 1) a ^= i;
                else b^=i;
            }
           
            return {a,b};
        }
    };
    

    4.总结

    这道题整体的思路是这样的,我们先找出ret = a ^ b来,主要是为了确定这俩数字哪个二进制位不一样,方便将其归纳到不同的组中去,两个消失的数字归纳到不同的组之后我们可以用异或的两两相消原理,把重复的数字全部干掉,一组只剩下a,一组只剩下b,返回即可。

    拓展:位运算常用操作:LINK


    EOF

  • 相关阅读:
    零零信安-D&D数据泄露报警日报【第42期】
    openGauss gsql 常用元命令 一
    【Mac OS】超好用的几个文字编辑快捷键
    Arduino驱动BMI160 6轴惯性运动传感器(惯性测量传感器篇)
    Spring Boot 第三篇:理解 spring-boot-starter-parent
    广东的介绍
    JavaScript_notes
    智能制造云办公 v3.7.25 发布,微服务拆分
    计算机视觉发展历史、优势以及面临的挑战
    自然资源-做好用地用海国土空间规划符合性审查
  • 原文地址:https://blog.csdn.net/2302_79031646/article/details/139332482
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | 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号