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

美食网站建设总结网站alexa排名查询

美食网站建设总结,网站alexa排名查询,web登录界面,设计网站推荐视频题目简介 一个数组中只有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.wangmingla.cn/news/166943.html

相关文章:

  • 泉州做网站工作室b2b网站免费推广平台
  • 网站设计师工作内容上海最新发布
  • 网站做app的软件叫什么宣传推广的形式有哪些
  • 政府网站开发项目技术总结书广告推销
  • 网站中图片中间是加号怎么做站长工具seo综合查询烟雨楼
  • 中企动力做网站软文推广的好处
  • 郑州做网站公司+卓美徐州网站建设方案优化
  • 瘦身网站开发目的成年培训班有哪些
  • 汽车报价大全免费seo工具
  • 网站配图尺寸每日财经要闻
  • 怎么用PHP做网站留言板郑州网站建设十大公司
  • 公司销售网站怎么做seo优化顾问
  • 请科技公司做网站需要注意什么优化网站关键词排名软件
  • 静海网站建设大连seo网站推广
  • 网站集约化 建设方案产品推广思路
  • 微网站建设微网站建设手机网站智能建站
  • 图片设计网站推荐白酒最有效的推广方式
  • 国内有什么网站杭州搜索引擎推广排名技术
  • 理财产品网站开发文档seo关键词怎么优化
  • 网站建设报价 福州seo的作用主要有
  • 卧龙区网站建设哪家好百度指数有什么作用
  • 网站是如何盈利seo的工作内容
  • 武汉关键词排名工具seo技巧是什么
  • 查企业营业执照的网站青岛百度网站排名优化
  • 东莞创意网站设计系统开发
  • 大型用户网站建设如何在百度上建立网站
  • 自由做图网站管理人员课程培训
  • 从事网站开发需要的证书网站推广的基本方法是
  • 柳州网站建设提高网站排名软件
  • 目前流行的网站开发技术百度网址安全中心