当前位置: 首页 > news >正文

力扣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 = 单元素,最后剩下的单元素就是我们要找的不重复的元素。

class Solution {
	public int singleNumber(int[] nums) {
		int result = 0;
		for(int num : nums){
			result ^= num;
		}
		return result;
	}
}

相关文章:

  • 突破连接边界!O9201PM Wi-Fi 6 + 蓝牙 5.4 模块重新定义笔记本无线体验
  • 低空经济安全保障体系构建方案
  • 【Unity】 HTFramework框架(六十二)Agent编辑器通用智能体(AI Agent)
  • 【NLP】 5. Word Analogy Task(词类比任务)与 Intrinsic Metric(内在度量)
  • “量超融合”突破 澳Quantum Brilliance融资2000万美元探索量子与超算协同
  • 事件驱动架构(EDA):微服务世界的未来趋势
  • UNI-APP uts插件 支持ANDROID 监听手机状态
  • 分布式锁: 并发时,redis如何避免删别人的锁
  • uniapp笔记-底部和首部标签页菜单生成
  • Matlab 汽车ABS实现pid控制
  • SpringBoot桂林旅游景点导游平台开发与设计
  • 【第14届蓝桥杯】软件赛CB组省赛
  • Cannl 数据同步-ES篇
  • Git 常用命令完全指南:从入门到高效协作
  • 【商城实战(39)】Spring Boot 携手微服务,商城架构焕新篇
  • 华为OD机试 - 九宫格按键输入 - 逻辑分析(Java 2023 B卷 200分)
  • helm部署metricbeat
  • 巧用 VSCode 与 AI 编码提升 Vue 前端开发效率
  • Vue 登录 记住密码,设置存储时间
  • R语言——变量
  • 长三角铁路今日预计发送旅客420万人次,有望创单日客发量新高
  • 七部门联合发布《终端设备直连卫星服务管理规定》
  • 武汉楼市新政:二孩、三孩家庭购买新房可分别享受6万元、12万元购房补贴
  • 浪尖计划再出发:万亿之城2030课题组赴九城调研万亿产业
  • 《求是》杂志发表习近平总书记重要文章《激励新时代青年在中国式现代化建设中挺膺担当》
  • 圆桌|如何应对特朗普政府的关税霸凌?一种联合国视角的思考