根据数字生成唯一数字_数组中两个只出现一次的数字-唯一只出现一次的数字...

ece68b156a0c4570c028e137e6f07355.png
  • 可以用异或,两个相同的数字异或是0,不同的数字异或 不为0
  • 分成两组:划分方法:
    • 首先把所有数字异或,因为两个数字不同,结果肯定有不是0的位
    • 找到第一个不是0的位,然后根据这个划分成两组,一个为0,一个为1:
      • 方法是:右移N位,然后&1,结果如果是1,就是1
    • 然后分别对每一组取异或,分别得到两个数字

354971ba94accc305703d4d4334d2a70.png

2.*****************数组中其他数字出现三次,只有一个出现一次**********************

题目描述

  • 在一个数组中除一个数字只出现一次之外,其他数字都出现了三次
  • 请找出那个只出现一次的数字

题目解读

  • 剑指Offer 278
  • 如果一个数字出现三次,那么它的二进制表示的每一位( 0 或者 1 )也出现三次。如果把所有出现三次的数字的二进制表示的每一位都分别加起来,那么每一位的和都能被 3 整除
  • 我们把数组中所有数字的二进制表示的每一位都加起来。如果某一位的和能被 3 整除,那么那个只出现一次的数字二进制表示中对应的那一位是 0 ;否则就是 1

95b55cff841f9ec032679f6e9f6fa922.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值