【算法专题突破】--- 位运算 --- 丢失的数字(难度⭐) 只出现一次的数字 III (难度⭐⭐) 消失的两个数字(难度⭐⭐⭐)(2)

一,丢失的数字

1. 题目解析

题目链接:268. 丢失的数字

这个问题的理解其实相当简单,只需看一下示例,基本就能明白其含义了。

2.算法原理

首先,我们设定一个长度为n的数组。理想情况下,如果这个数组是从0到n-1的连续整数序列,那么它应该包含所有从0到n-1的整数。但是,由于某种原因,数组中缺失了一个数字,因此它现在是一个不完整的序列。

我们的目标是找出这个缺失的数字。为了实现这一目标,我们可以利用异或运算的一个关键特性,即任何数和0进行异或运算,结果仍然是原来的数;而任何数和其自身进行异或运算,结果则为0。这一特性使得异或运算在解决这类问题时非常有用。

我们可以按照以下步骤来寻找缺失的数字:

  1. 初始化异或结果:首先,我们设置一个变量来保存异或运算的结果,初始值为0。这个变量将用于存储所有应该出现在数组中的数字(即从0到n-1的所有整数)的异或结果。
  2. 计算应该存在的数字的异或:接下来,我们遍历从0到n-1的所有整数,并将它们依次与异或结果变量进行异或运算。这样,我们就得到了一个包含了所有应该存在于数组中的数字的异或结果。
  3. 计算实际数组中数字的异或:然后,我们遍历数组中的每一个数字,并将它们也依次与异或结果变量进行异或运算。由于数组中的数字与前面计算出的应该存在的数字的集合相比,只有一个数字是缺失的,因此这一步操作实际上是将这个缺失的数字从异或结果中“消除”了。
  4. 得出缺失的数字:最后,由于异或运算的“消消乐”特性,最终保存在异或结果变量中的数字,就是那个在数组中缺失的数字。

通过以上步骤,我们可以有效地找出数组中缺失的那个数字,而无需显式地检查每一个可能的数字是否存在于数组中。这种算法的时间复杂度是O(n),其中n是数组的长度,因此它对于处理大规模数据集也是相当高效的。

3.代码编写

class Solution 
{
public:
    int missingNumber(vector<int>& nums) 
    {
        int size = nums.size(), ret = size;
        for(int i = 0; i < size; i++) ret ^= i ^ nums[i];
        //for(const auto &x : nums) ret ^= x;
        return ret;
    }
};

二,只出现一次的数字III

1. 题目解析

题目链接:260. 只出现一次的数字 III

这个问题的理解其实相当简单,只需看一下示例,基本就能明白其含义了。

2.算法原理

一种计算lowbit的方式,就是保留数字的二进制表示中最低位的1,其余位均置为0。举例来说:

  • 设 s 的二进制为 101100,首先我们对 s 进行按位取反得到 ~s,结果为 010011。
  • 接着,我们将 ~s 加 1,根据补码的定义,这实际上相当于计算了 -s,结果是 010100。
  • 此时,我们可以观察到 -s 的效果是将 s 中最低位的1左侧的所有位取反,而最低位1右侧的位保持不变。
  • 最后,我们将 s 与 -s 进行按位与运算,得到 s & -s 的结果为 000100。这样,我们就成功地保留了 s 的最低位的1,而将其余位都置为了0。

3.代码编写

class Solution 
{
public:
    vector<int> singleNumber(vector<int>& nums) 
    {
        size_t tmp = 0;
        for(auto x : nums) tmp ^= x;
        int lowbit = tmp & -tmp;
        vector<int> ret(2);
        for(auto x : nums) ret[(x & lowbit) == 0] ^= x;
        return ret;
    }
};

三,消失的两个数字

1. 题目解析

这个问题的理解其实相当简单,只需看一下示例,基本就能明白其含义了。

2.算法原理

本题就是 一,丢失的数字 + 二,260. 只出现⼀次的数字 III   结合 起来的题。

我们将数组中的每个数与区间[1, n + 2]内的所有数依次进行异或操作。

通过这一步,问题便转化为:有两个数各出现了一次,而其余所有数均出现了两次。这就类似于我们熟知的“只出现一次的数字 III”这道题目。

3.代码编写

class Solution 
{
public:
    vector<int> missingTwo(vector<int>& nums) 
    {
        //丢失的数字
        size_t tmp = 0, n = nums.size();
        for(auto x : nums) tmp ^= x;
        for(int i = 1; i <= n + 2; i++) tmp ^= i;
        //只出现一次的数字III
        int lowbit = tmp & -tmp;
        vector<int> ret(2);
        for(auto x : nums) ret[(x & lowbit) == 0] ^= x;
        for(int i = 1; i <= n + 2; i++) ret[(i & lowbit) == 0] ^= i;
        return ret;
    }
};

The Last

嗯,就是这样啦,文章到这里就结束啦,真心感谢你花时间来读。

觉得有点收获的话,不妨给我点个吧!

如果发现文章有啥漏洞或错误的地方,欢迎私信我或者在评论里提醒一声~ 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/472513.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

机器人路径规划:基于鳑鲏鱼优化算法(Bitterling Fish Optimization,BFO)的机器人路径规划(提供MATLAB代码)

一、机器人路径规划介绍 移动机器人&#xff08;Mobile robot&#xff0c;MR&#xff09;的路径规划是 移动机器人研究的重要分支之&#xff0c;是对其进行控制的基础。根据环境信息的已知程度不同&#xff0c;路径规划分为基于环境信息已知的全局路径规划和基于环境信息未知或…

CSDN学习笔记总索引(2024)——我的创作纪念日(1024)

从2021-05-21至2024-03-19&#xff0c;我的CSDN博文学习笔记中&#xff0c;收集并展示浏览阅读&#xff0c;点赞收藏评论等数据&#xff0c;以浏览阅读量排逆序展示。 (笔记模板由python脚本于2024年03月19日 05:49:24创建&#xff0c;本篇笔记适合熟悉Python&#xff0c;对其基…

一维数组数组名的用途

大家好&#xff1a; 衷心希望各位点赞。 您的问题请留在评论区&#xff0c;我会及时回答。 一、数组名的用途 一维数组数组名的用途&#xff1a; 1、可以统计整个数组的长度。 2、可以获取数组在内存中的首地址。 二、示例代码 #include <iostream> #include <W…

亚马逊等跨境电商平台自养号测评的五个核心因素

一、安全稳定的环境系统 尽管市场上存在大量现成的系统和软件包&#xff0c;卖个软件或设备给你&#xff0c;这种基本上都没有解决风控的能力&#xff0c;因此&#xff0c;小编推荐大家还是自己掌握相关技术&#xff0c;避免过度依赖于外部资源&#xff0c;目前&#xff0c;也…

C语言救赎之路,有些鸟儿是困不住的!(其4) (逻辑运算符+函数)

什么是运算符&#xff1f;诶~&#xff0c;其实我们一直在用运算符&#xff0c;比如我们的 &#xff0c;-&#xff0c;*&#xff0c;/ 等等都是运算符。今天我们就先来讲讲运算符。这是结合我自己的理解&#xff0c;我认为自己讲的肯定比一些教科书讲的要更清楚一些&#xff0c;…

SpringBoot整合Xxl-Job

一、下载Xxl-Job源代码并导入本地并运行 Github地址:GitHub - xuxueli/xxl-job: A distributed task scheduling framework.&#xff08;分布式任务调度平台XXL-JOB&#xff09; 中文文档地址:分布式任务调度平台XXL-JOB 1.使用Idea或Eclipse导入 2.执行sql脚本(红色标记…

nfs介绍与配置

NFS 1. nfs简介 nfs特点 NFS&#xff08;Network File System&#xff09;即网络文件系统&#xff0c;是FreeBSD支持的文件系统中的一种&#xff0c;它允许网络中的计算机之间通过TCP/IP网络共享资源在NFS的应用中&#xff0c;本地NFS的客户端应用可以透明地读写位于远端NFS服…

动态规划课堂6-----回文串问题

目录 引言&#xff1a; 例题1&#xff1a;回文子串 例题2&#xff1a;回文串分割IV 例题3&#xff1a;分割回文串II 例题4&#xff1a;最长回文子序列 例题5&#xff1a;让字符串成为回文串的最小插入次数 引言&#xff1a; 回文字符串 是正着读和倒过来读一样的字符串。…

LeetCode 面试经典150题 80.删除有序数组中的重复项II

题目&#xff1a; 给你一个有序数组 nums &#xff0c;请你 原地 删除重复出现的元素&#xff0c;使得出现次数超过两次的元素只出现两次 &#xff0c;返回删除后数组的新长度。 不要使用额外的数组空间&#xff0c;你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件…

PTA——1075 链表元素分类、1105 链表合并、1110 区块反转

1075 链表元素分类 解决代码 #include<bits/stdc.h> using namespace std; struct node{int v;int next; }; map<int,node> s; vector<vector<pair<int,int>>> ans(3); vector<pair<int,int>> w; int main(){int st,n,k;cin>>…

鸿蒙Harmony应用开发—ArkTS-转场动画(组件内转场)

组件内转场主要通过transition属性配置转场参数&#xff0c;在组件插入和删除时显示过渡动效&#xff0c;主要用于容器组件中的子组件插入和删除时&#xff0c;提升用户体验。 说明&#xff1a; 从API Version 7开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记…

短视频矩阵系统技术交付

短视频矩阵系统技术交付&#xff0c;短视频矩阵剪辑矩阵分发系统现在在来开发这个市场单个项目来说&#xff0c;目前基本上已经沉淀3年了&#xff0c;那么我们来就技术短视频矩阵剪辑系统开发来聊聊 短视频矩阵系统经过315大会以后&#xff0c;很多违规的技术开发肯定有筛选到了…

cuda多版本安装

主要参考文章&#xff1a; ubuntu 20.04下多版本cuda&cudnn下载与安装 在ubuntu上安装多个版本的CUDA&#xff0c;并且可以随时切换 1 环境检查 nvidia-smiCUDA Version:12.4表示最高支持cuda 12.4版本 nvcc -V如图所示表示系统目前版本为cuda 12.2 2 多版本cuda下载与…

深入解析Kafka中的动态更新模式

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 深入解析Kafka中的动态更新模式 前言动态更新模式的基础概念动态更新模式的概念&#xff1a;解决的问题和引入的原因&#xff1a; 原理解析与工作流程动态更新模式的工作原理和工作流程&#xff1a;示…

【MySQL】学习和总结使用列子查询查询员工工资信息

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-5odctDvQ0AHJJc1C {font-family:"trebuchet ms",verdana,arial,sans-serif;font-siz…

Spring-IOC容器注解方式整合三层架构

注解方式特点 //1. 完全注解方式指的是去掉xml文件&#xff0c;使用配置类 注解实现 //2. xml文件替换成使用Configuration注解标记的类 //3. 标记IoC注解&#xff1a;Component,Service,Controller,Repository //4. 标记DI注解&#xff1a;Autowired Qualifier Resource Va…

基于肤色模型(YCbCr模型)的人面定位统计算法,Matlab实现

博主简介&#xff1a; 专注、专一于Matlab图像处理学习、交流&#xff0c;matlab图像代码代做/项目合作可以联系&#xff08;QQ:3249726188&#xff09; 个人主页&#xff1a;Matlab_ImagePro-CSDN博客 原则&#xff1a;代码均由本人编写完成&#xff0c;非中介&#xff0c;提供…

计算机视觉之三维重建(2)---摄像机标定

文章目录 一、回顾线代1.1 线性方程组的解1.2 齐次线性方程组的解 二、透镜摄像机的标定2.1 标定过程2.2 提取摄像机参数2.3 参数总结 三、径向畸变的摄像机标定3.1 建模3.2 求解 四、变换4.1 2D平面上的欧式变换4.2 2D平面上的相似变换和仿射变换4.3 2D平面上的透射变换4.4 3D…

音视频开发_SDL跨平台多媒体开发库实战

SDL&#xff08;Simple DirectMedia Layer&#xff09;是一个非常流行和强大的跨平台开发库&#xff0c;它主要被用来开发视频游戏和实时多媒体应用程序。它提供了一系列的功能来处理视频、音频、键盘、鼠标、操纵杆、图形硬件加速以及聚焦3D硬件的各种功能。SDL的API通过C编程…

串行通信协议 SPI

SPI&#xff08;Serial Peripheral Interface&#xff09;是一种串行通信协议&#xff0c;常用于连接微控制器、存储器、传感器和其他外围设备。SPI通常由一个主设备&#xff08;通常是微控制器&#xff09;和一个或多个从设备组成。 1、SPI通信一般由四根线组成: SCLK&#x…