news 2026/5/17 0:12:29

力扣 只出现一次的数字

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣 只出现一次的数字

题目:

给你一个非空整数数组nums,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素。

你必须设计并实现线性时间复杂度的算法来解决此问题,且该算法只使用常量额外空间。

题解:

我觉着这是很有意思的一道题

该问题看似简单,但在时间和空间复杂度限制下,非常考察对位运算的理解。

一、最直观的思路(为什么不选)

1,使用哈希表统计次数

最容易想到的方式是:

  • 使用哈希表记录每个数字出现的次数

  • 再遍历哈希表,找出次数为 1 的元素

问题:

  • 需要额外的存储空间

  • 空间复杂度为O(n)

而本题的隐含要求是:
使用常量额外空间


2, 排序后相邻比较

另一种思路是:

  • 对数组排序

  • 成对比较相邻元素

问题:

  • 排序时间复杂度至少为O(n log n)

  • 不满足最优解要求

二、最优解的核心思想:异或运算

1,什么是异或(XOR)

异或运算有几个非常重要的性质:

  1. 相同的数异或为 0

    a ^ a = 0

  2. 任何数与 0 异或仍是它本身

    a ^ 0 = a

  3. 异或满足交换律和结合律

    a ^ b ^ a = b


2,这些性质意味着什么?

在数组中:

  • 每个出现两次的数字

    x ^ x = 0

  • 所有成对的数字最终都会“抵消”为 0

  • 剩下的唯一一个数:

    0 ^ single = single

只出现一次的数字一定会被保留下来

三、算法思路(核心逻辑)

  1. 初始化一个变量res = 0

  2. 遍历数组中每一个元素

  3. 将当前元素与res进行异或运算

  4. 遍历结束后,res就是只出现一次的数字

整个过程:

  • 不需要额外的数据结构

  • 只做一次遍历

  • 完全利用位运算完成

四、总结

  • 本题的关键不在于遍历,而在于如何“消掉”重复元素

  • 异或运算天然适合处理:

    • 成对出现

    • 只剩一个不同值

  • 这是位运算在算法题中的经典应用

一句话总结:

利用异或“相同为零、不同保留”的特性,让所有成对数字互相抵消,最终剩下的就是答案。

class Solution { public: int singleNumber(vector<int>& nums) { int ans = 0; for (int x : nums) { ans ^= x; } return ans; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/17 0:14:23

渗透测试之Kali漏洞扫描工具详解

【强烈收藏】Kali Linux 21款网络安全工具详解&#xff1a;从信息收集到渗透测试&#xff0c;小白也能快速上手 本文介绍了Kali Linux上的21款网络安全工具&#xff0c;包括Nmap、Wireshark、Metasploit等&#xff0c;涵盖信息收集、漏洞扫描、渗透测试、网络分析等多个方面。…

作者头像 李华
网站建设 2026/5/15 18:10:12

AI如何帮你快速掌握Vue3文档核心要点

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个基于Vue3的AI辅助学习应用&#xff0c;能够自动解析Vue3官方文档&#xff0c;提取核心概念和API说明&#xff0c;并生成对应的代码示例。应用应包含以下功能&#xff1a;1)…

作者头像 李华
网站建设 2026/5/16 20:57:14

虚拟转子运动方程

光伏混合储能VSG讲解一一光储一次调频、功率平抑、 直流母线电压控制。光伏电站并网后像个叛逆期的孩子&#xff0c;总喜欢甩开电网调度自己玩。这时候虚拟同步发电机&#xff08;VSG&#xff09;技术就像个严厉的班主任&#xff0c;让光伏系统学会"守规矩"。今天咱们…

作者头像 李华
网站建设 2026/5/13 14:35:02

中山网络推广营销:低成本高效益的中小企业营销实操指南

对于中山中小企业来说&#xff0c;数字化营销的兴起为其提供了前所未有的机会。然而&#xff0c;预算有限和人力短缺依然是这些企业在进行网络营销时面临的主要挑战。本文将围绕这些痛点&#xff0c;提供一系列低成本、可执行的网络推广方案&#xff0c;帮助中山的中小企业从基…

作者头像 李华
网站建设 2026/5/16 4:44:53

SQL初学者指南:5分钟搞懂union和union all

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个面向初学者的SQL学习应用&#xff0c;重点讲解union和union all。要求&#xff1a;1. 卡通化交互界面 2. 分步骤动画演示 3. 可交互的简单示例 4. 即时反馈练习系统 5. 错题…

作者头像 李华
网站建设 2026/5/11 20:21:44

15分钟用高德地图MCP搭建出行应用原型

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 快速开发一个出行应用原型&#xff0c;集成高德地图MCP&#xff0c;实现以下核心功能&#xff1a;1. 地图展示&#xff1b;2. 起点终点输入&#xff1b;3. 路线规划&#xff1b;4. …

作者头像 李华