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

力扣HOT100之技巧:136. 只出现一次的数字


这道题一开始想着用哈希表来做,但是如果用哈希表来做的话空间复杂度为O(n),我们还需要使用其他的技巧,这里我们使用异或操作。首先,我们需要知道异或的以下性质:
对于任意整数a,有

  1. 0 ^ a = a
  2. a ^ b = b ^ a(交换律)
  3. a ^ a = 0
  4. (a ^ b) ^ c = a ^ (b ^ c) (结合律)
    根据交换律和结合律,我们可以将数组中出现两次的数都挪到前面,定义一个变量result,初始化为0,然后通过一个for循环实现0 ^ a1 ^ a1' ^ a2 ^ a2'... ^ b,根据以上的性质,最终将化简为0 ^ b = b,其中ai == ai'b为仅出现一次的元素,按照上面的操作,我们最终会计算出仅出现一次的元素,返回即可。
class Solution {
public:int singleNumber(vector<int>& nums) {int result = 0;for(int i = 0; i < nums.size(); i++)result = result ^ nums[i];return result;}
};
http://www.xdnf.cn/news/1001701.html

相关文章:

  • C#调用C++ 结构体方法
  • GitHub 上 PAT 和 SSH 的 7 个主要区别:您应该选择哪一个?
  • Transformer 与 XGBoost 协同优化的时间序列建模
  • LSTM助力迁移学习!深度学习架构性能提升,准确率达到99.91%!
  • TCN+Transformer+SE注意力机制多分类模型 + SHAP特征重要性分析,pytorch框架
  • 用于在多个远程计算机上求解的 Ansoft RSM 设置 - Windows
  • 实战案例-FPGA的JESD204B IP核配置详解
  • 【springboot组件开发】三方中间件自定义自动装载(rabbitmq/rocketmq/cmq)
  • 记录一次jenkins slave因为本地安装多个java版本导致的问题
  • stm32f103 标准库移植rt-thread nano
  • 学习笔记整理之状态图与状态图搜索
  • Windows 提权工具(“Potato“ 系列)用法指南
  • 火线、零线、地线 基础知识
  • 实现图片懒加载
  • 大话软工笔记—架构的概要设计
  • 【AS32系列MCU调试教程】基础配置:Eclipse项目与工具链的优化
  • SD-WAN优化云应用与多云架构访问的关键策略
  • 408考研逐题详解:2009年第39题
  • 深入探索IIC-OLED显示技术:嵌入式仿真平台如何重塑高校教学范式——深圳航天科技创新研究院技术赋能新一代工程教育
  • 观点 | 科技企业到了品牌建设的历史性窗口期
  • 界面开发框架DevExpress XAF实践:集成.NET Aspire后如何实现服务安排?
  • Kratos 与Golang Cms的关系
  • 深度学习环境搭建(pycharm+yolov5)
  • 【AWS入门】IAM多重身份验证(MFA)简介
  • 深度解析Git错误:`fatal: detected dubious ownership in repository` 的根源与解决方案
  • OpenAI API:LLM编程的事实标准(上)
  • R语言缓释制剂QBD解决方案之五
  • GitLab 拉取变慢的原因及排查方法
  • UE5 学习系列(九)光照系统介绍
  • linux中的locate命令