力扣136. 只出现一次的数字

Problem: 136. 只出现一次的数字

文章目录

题目描述

思路

由于题目要求使用线性时间复杂度和常量级的空间复杂度 ,再加上找重复元素 这个特性,我们可以想到使用位运算来求解:

1.任何数与其本身异或得0,任何数与0异或得到其本身

2.由于只有一个数字出现一次,其余的数均出现两次,则定义int变量temp初始化为0,循环每次与nums[i]异或,最终返回temp,即为只出现一次的数

复杂度

时间复杂度:

O ( n ) O(n) O(n);其中 n n n为数组nums的大小

空间复杂度:

O ( 1 ) O(1) O(1)

Code

cpp 复制代码
class Solution {
public:
	/// <summary>
	/// Find a number that only appears once
	/// </summary>
	/// 
	/// <param name="nums"> The given array </param>
	/// <returns> int </returns>
	int singleNumber(vector<int>& nums) {
		int temp = 0;
		for (int i = 0; i < nums.size(); ++i) {
			temp ^= nums[i];
		}
		return temp;
	}
};
相关推荐
nunca_te_rindas几秒前
算法刷体小结汇总(C/C++)20260328
c语言·c++·算法
Sunshine for you3 分钟前
高性能压缩库实现
开发语言·c++·算法
Sunshine for you4 分钟前
C++中的表达式模板
开发语言·c++·算法
qwehjk20085 分钟前
C++中的状态模式
开发语言·c++·算法
Fortune799 分钟前
自定义类型转换机制
开发语言·c++·算法
nunca_te_rindas9 分钟前
递归实现排列型枚举题目例题
算法
2301_8145902510 分钟前
实时音频处理C++实现
开发语言·c++·算法
Lisssaa25 分钟前
打卡第二十八天
数据结构·算法
小此方28 分钟前
算法实战论01(双指针篇一):双指针的核心思想与应用场景总结
c++·算法·力扣
2401_8785302133 分钟前
C++与FPGA协同设计
开发语言·c++·算法