每日一题——只出现一次的数字

简介: 每日一题——只出现一次的数字

只出现一次的数字

题目链接

思路

要求为线性时间复杂度,即时间复杂度为O(n),那么我们就不能用简单的两层循环来解决问题

要求只能使用常量额外空间,即空间复杂度为O(1),那么我们就不能额外开辟一个数组来记录每个元素出现的次数

这里,给大家介绍一个全新的方法:位运算——异或^

注:如果对位运算符还不太了解,建议先看看👉位运算详解

异或的特性:

异或是支持交换律的:a ^ b ^ c = b ^ a ^ c

a ^ a = 0相同的数异或为0

0 ^ a = a一个数和0异或得到的还是本身

那么我们就可以利用异或的这些特性,来解决这个问题。

题目告诉我们,数组中除某一个元素只出现一次外,其余元素都出现了两次,那么我们将数组的所有元素都异或到一起,不就可以得到只出现一次的那一个数了吗?

实现代码

int singleNumber(int* nums, int numsSize)
{
    int ret = 0;
    for(int i = 0; i < numsSize; i++)
        ret ^= nums[i];
    return ret;
}

通过这一道题,最重要的就是掌握异或的特性,这有利于后续许多问题的解决

相关文章
|
Ubuntu Linux
百度搜索:蓝易云【Ubuntu更改默认启动内核】
请注意,更改默认启动内核可能会影响系统的稳定性和性能。在更改前,请确保选择的内核版本与你的系统硬件和配置兼容。如果遇到问题,你可以在GRUB启动菜单中选择其他内核来启动系统,并在问题解决后再将默认内核设置为你选择的版本。
388 0
|
8月前
|
自然语言处理 算法 前端开发
Go语言实战案例-判断回文字符串-是不是正着念反着念都一样?
本案例实现判断回文字符串程序,支持中文、英文、标点及空格处理。通过双指针法与Unicode字符比较,帮助读者掌握字符串处理技巧与逻辑编程基础。
|
存储 缓存 关系型数据库
深入解析MySQL中的表类型及其应用场景
【8月更文挑战第31天】
1148 0
|
Rust API 开发者
【一起学Rust | 框架篇 | ws-rs框架】属于Rust的Websocket框架——ws-rs
【一起学Rust | 框架篇 | ws-rs框架】属于Rust的Websocket框架——ws-rs
1741 0
|
机器学习/深度学习 PyTorch 算法框架/工具
PyTorch代码实现神经网络
这段代码示例展示了如何在PyTorch中构建一个基础的卷积神经网络(CNN)。该网络包括两个卷积层,分别用于提取图像特征,每个卷积层后跟一个池化层以降低空间维度;之后是三个全连接层,用于分类输出。此结构适用于图像识别任务,并可根据具体应用调整参数与层数。
360 9
|
Java
每日一题《剑指offer》数组篇之数组中重复的数字
每日一题《剑指offer》数组篇之数组中重复的数字
145 0
每日一题《剑指offer》数组篇之数组中重复的数字
剑指 Offer 18. 删除链表的节点
剑指 Offer 18. 删除链表的节点
144 0
|
机器学习/深度学习 传感器 调度
【语音信号显示】麦克风实时时域和频域图matlab实现
【语音信号显示】麦克风实时时域和频域图matlab实现
|
Java
每日一题《剑指offer》字符串篇之字符串的排列
每日一题《剑指offer》字符串篇之字符串的排列
147 0
每日一题《剑指offer》字符串篇之字符串的排列
|
机器学习/深度学习 数据可视化 数据挖掘
模拟生成问卷数据
模拟生成问卷数据
1059 0

热门文章

最新文章