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

网站管理页面cba最新积分榜

网站管理页面,cba最新积分榜,汽车配件加工网,购物网站开发的背景java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846 文章目录 与运算取末尾1分组 与运算取末尾1分组 解题思路:时间…
java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/123063846

文章目录

    • 与运算取末尾1分组

在这里插入图片描述

与运算取末尾1分组

解题思路:时间复杂度O( n n n),空间复杂度O( 1 1 1)
  1. 数组中有两个元素a和b出现1次,剩余都出现2次
  2. 通过异或操作,将出现2次的都抵消掉,获得两个出现一次的数的异或结果a^b
  3. 我们知道a^b的结果是,两者二进制中,值不同的位 = 1,相同的 = 0.
  4. 我们拿到a^b的最右边一个1,也就是a和b最右边的不相同的一位rightOne。也就是说rightOne位置,a的二进制和b的二进制不同,一个1,一个0

获取a的二进制最右边的1的经典操作办法是 rightOne = a & (-a).如果不懂,可以参考下面文章中,与运算的讲解

位运算https://blog.csdn.net/grd_java/article/details/136119268
  1. 既然我们拿到了rightOne。他的二进制形式是整个二进制串,只有一个1,例如0000010000,而这个1的位置,是区分a和b的关键,因为a和b中,只有一个在rightOne的位置是1.而另一个一定是0. 因为a^b后,1的位置代表a和b不同的位置
  2. 这样我们将整个数组分成两组,在rightOne位置为1的,和在rightOne位置为0的
  3. 然后我们对在rightOne位置为1的所有数字,进行异或统计。其中出现两次的数字,二进制不会有什么改变,在rightOne位置的二进制都一样。所以异或过程中,依然会抵消掉。最终结果会剩下出现一次的数字。a和b的一员。这里假设为a。

因为a和b只有一个在rightOne位置是1,这里假设a在rightOne位置是1.而a只出现1次,其它在rightOne位置是1的数都出现两次。异或后都会抵消。最终只剩下a

  1. 这样我们就找到了一个出现一次的数字a。然后我们还有a^b的结果,我们将a^b^a = (a^a)^b = 0^b = b.这样就找到了a和b。返回即可。
代码

在这里插入图片描述

class Solution {public int[] singleNumber(int[] nums) {int eor1 = 0;//对所有数进行异或,最后将剩下两个只出现一次的数for (int num : nums) eor1 ^= num;//两数相同异或为0,不同异或为1// eor1 : a ^ b,a和b的二进制位,如果不同结果就是1// 正负相与,保留最末尾的1int RightOne = eor1 & (-eor1);//提取最右侧的1,表示a和b二进制中,最右侧第一个两者不一样的一位,也就是这一位二进制,a和b不一样。一个在这一位是1,一个在这一位是0int eor2 = 0;//分组,保存所有在这一位是0的数的异或结果。而另一组在这一位是1的异或结果,我们可以不做统计for (int num : nums) {//遍历所有数if ((num & RightOne) == 0) {//如果num在这一位是0,而RightOne在这一位肯定是1,相与的结果必然是0,而其它位rightOne都是0,所以最终整个二进制结果一定是0eor2 ^= num;//将其进行异或,最终出现两次的都会抵消,而一定会遇上a和b中这一位是0的那个,假设是a,然后eor2 = a}}return new int[] { eor2, eor1 ^ eor2 };//eor1 = a^b 假设eor2 = a.则eor1 ^ eor2 = a ^ b ^ a = b }
}
http://www.hkea.cn/news/931472/

相关文章:

  • wordpress做网站优点郑州网站seo优化
  • 宝安做棋牌网站建设找哪家公司好湖南长沙疫情最新消息
  • 四川专业网站建设中国十大企业培训机构排名
  • 怎么切页面做网站灰色词首页排名接单
  • 网站右侧浮动广告代码百度推广代理公司广州
  • 固原建站公司旺道seo推广系统怎么收费
  • 适合做外链的网站海外广告联盟平台推广
  • 建筑模板规格型号郑州厉害的seo顾问
  • ppt做书模板下载网站有哪些内容国际婚恋网站排名
  • 上海网站建设内容更新网络营销策划目的
  • 重庆市建设信息网站关键词查询网
  • 做哪种网站流量大怎么打广告宣传自己的产品
  • 免费表白网站制作seo网络优化推广
  • 网站建设中可能升级中国科技新闻网
  • 网站制作内容文案网站如何快速被百度收录
  • 淘宝淘宝网页版登录入口免费seo公司
  • 竹溪县县建设局网站短视频营销
  • 好的网站有哪些搜索引擎seo是什么意思
  • 做音乐网站赚钱吗做小程序的公司
  • 坪地网站建设域名流量查询工具
  • 网站建设部署万能推广app
  • 网站的重要性怎么做个网站
  • 做网站的经验百度旗下有哪些app
  • 化工网站开发推广点击器
  • 怎么访问日本竹中建设网站外贸seo推广
  • 惠阳建设局网站引流推广接单
  • 北京通州网站建设公司如何建立公司网站网页
  • 网站换程序301seo优化按天扣费
  • html5 网站自适应长尾关键词挖掘爱站工具
  • 网站设计公司(信科网络)潍坊网站定制模板建站