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

难点在于时间与空间复杂度的要求,一般遇到这样的限制,就要考虑使用位运算,位运算效率最高了。

异或

当且仅当两个输入值不同时,异或运算输出为真(1),否则输出为假(0),即"同为 0,异为 1"。

这是针对二进制运算的规则,整数进行异或运算,需要转换为二进制,一样遵循这个运算规则。

异或的运算律:

交换律:p ⊕ q = q ⊕ p

结合律:p ⊕ (q ⊕ r) = (p ⊕ q) ⊕ r
恒等律:p ⊕ 0 = p
归零律:p ⊕ p = 0
对合运算:p ⊕ q ⊕ q = p ⊕ 0 = p

逆元:对于任何布尔值 a, 有 a ⊕ 0 = a 与 a ⊕ a = 0, 即对于异或操作,每一个布尔值 a 的逆元就是它本身。

由以上性质可得,若 A ⊕ B = C ,则 A ⊕ C = B 且B ⊕ C = A。可以用这条性质进行简单的数据交换。

本题就需要应用异或的上述性质,因为数组中除了一个元素外,每个元素都有重复的元素,而重复的元素相异或就为0,异或满足交换率,因此最后的结果只剩单元素 ^ 0 = 单元素,最后剩下的单元素就是我们要找的不重复的元素。

java 复制代码
class Solution {
	public int singleNumber(int[] nums) {
		int result = 0;
		for(int num : nums){
			result ^= num;
		}
		return result;
	}
}
相关推荐
bIo7lyA8v8 小时前
算法复杂度评估的实验统计方法与可视化的技术8
算法
李老师讲编程8 小时前
中国电子学会图形化2020.12月Scratch三级考级题
算法·scratch·信息学奥赛·图形化编程·scratch素材
退休倒计时8 小时前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript
旖-旎8 小时前
FloodFill(图像渲染)(1)
c++·算法·深度优先·力扣
戴西软件9 小时前
戴西 DLM 许可授权管理系统:破解无网络环境下工业软件授权难题,助力制造企业降本增效
网络·人工智能·python·深度学习·程序人生·算法·制造
2601_961875249 小时前
法考资料2026|全套|资料已整理
数据结构·算法·链表·贪心算法·eclipse·线性回归·动态规划
无限码力9 小时前
美团研发岗 4月18号笔试真题 - 坐标
算法·美团笔试真题·美团笔试题·美团研发岗笔试题·美团研发岗4月18号真题
有点。10 小时前
C++倍增法(练习题)
c++·算法
智者知已应修善业11 小时前
【51单片机8位数码管同时倒计时从9999】2024-1-25
c++·经验分享·笔记·算法·51单片机