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

电商网站的建设背景图片北京品牌网站定制公司

电商网站的建设背景图片,北京品牌网站定制公司,嘉定制作企业网站,专业地推团队题目简介 一个数组中只有2个数字只有一个,其他数字都有两个。找出这两个数字。a, b 用HashMap记录就不说了。 这里记录一下用异或的方式解决。 由于异或特性为自己异或自己为0。a^a 0;所以可以异或数组中的所有数字得出 a^b 的结果,其他相同的都消掉…

题目简介

一个数组中只有2个数字只有一个,其他数字都有两个。找出这两个数字。a, b

用HashMap记录就不说了。

这里记录一下用异或的方式解决。

  1. 由于异或特性为自己异或自己为0。a^a = 0;
  2. 所以可以异或数组中的所有数字得出 a^b 的结果,其他相同的都消掉了。
  3. 又a != b 因此,a^b 的结果在二进制中,肯定有一位是1。这个也好理解。

下面就是我半天不能理解的点了。这里记录一下。

上面说a^b 肯定有一位是1。然后通过遍历数组的所有项,以这一位是不是为1分成两组。

我就很纳闷,理解了很久,为什么以这个条件分成两组。

后来终于想到

因为a^b至少有一位是1的话,那么在a 和b的二进制当中,这一位一定是1个为0,一个为1。

比如:

a: xxx0xx,
b: xxx1xx,

这样通过这一位去分组的话。就拿到两个数组,分别存在a和b。这两个数组的其他项不用担心,也一定是有重复,可以异或成0的。

如:

arr1: [a, 1, 1, 2, 2];
arr2: [b, 2, 2, 3, 3];

进一步理解,既然a的这一位为0(举例),那么数组中其他这一位 为0的就不可能是b。

那我怎么知道其他这些数字能两两成对呢?

因为这一位是0 的数字有一个满足的话,那和他相同的那个数字也能满足。就一定是成对出现的。(反证法了属于😂)

这样通过遍历arr1 的所有项就能获取a的值了。

获取b的值也可以复用刚才a^b 的结果。使a^b^a = b了;

至于怎么获取这一位变成 0001000,就看其他文章,本文不做讨论。

代码就不放了。思路最重要。

http://www.laogonggong.com/news/59911.html

相关文章:

  • 雄安专业网站建设263企业邮箱登录邮箱
  • wordpress手机站主题30分钟seo网站
  • frontpage新建网站wordpress采集英文
  • 成品网站建设咨询小说引流推广
  • 目前最火的推广平台常州seo网站推广
  • 广东建设教育协会网站增城网站定制开发公司
  • 关键词排行优化网站网站建设制作 南京公司
  • 鹤壁建设网站推广渠道网站备案取消接入
  • 深圳做小程序网站设计数据库与网站建设
  • 赤峰网站建设 公司网站建设全网营销
  • 六安关于建设审批的网站网站建设技术开发
  • 古镇 网站建设中企动力企业邮箱手机登录入口
  • 海南建设工程股份有限公司网站做网站时链接的网页无法显示
  • 购物网站制作怎么做wordpress自定义文章模板插件
  • 北京华夏工程建设监理公司网站免费html网站模板下载
  • 做网站 前端怎么建立图片的网站
  • 汉中网站制作做仿牌网站
  • 阿里云可以几个网站推销产品的万能句子
  • 网站服务器租用技巧申请中网可信网站
  • 一百互联网站建设珠海航展表演
  • 手机网站用什么软件对电子商务网站建设与管理的理解
  • 遂宁网站开发南康家具网站建设
  • 正规的常州网站推广广东省建设安全中心网站
  • mip 网站模板怎么做网站音乐
  • 网站建设公司源码京津冀协同发展的基础
  • 模仿网站怎么做国外创意摄影网站
  • 洛阳建站公司效果本地南昌网站建设
  • 工程公司手机网站360全景网站怎么做
  • 中国建设银行保函查询网站盐城经济技术开发区建设局网站
  • 旅游网站模板htmlwordpress slug translate