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

成都网站建设设计公司排名怎么代码放到网站上

成都网站建设设计公司排名,怎么代码放到网站上,wordpress小工具编辑器,网络营销出来可以干什么工作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.yayakq.cn/news/933816/

相关文章:

  • 中国建设银行培训网站wordpress如何实现登录注册功能
  • 大同泰瑞集团建设有限公司网站北斗导航2022最新版手机版
  • 甜品网站设计网投怎么做网站
  • 建设审批网站查询网站制作代理平台
  • 手机网站整站模板下载网站里怎样添加关键词
  • 用vs做网站教程找个男做那个视频网站
  • 赚钱平台网站WordPress判断用户角色
  • 记录网站 自己做百度搜索软件
  • wordpress电影站主题木门行业网站该怎么做
  • 做视频网站要申请什么许可证海口网站设计公司
  • 做网站要有什么功能做网站技术路线
  • 简单的购物网站设计wordpress查看管理员密码
  • 如何自助建网站一站式建网站php网站系统
  • 建设外围彩票网站牡丹江47号公告
  • 关于春节的网站设计html都匀住房和城乡建设厅网站
  • 企业网站建设亮点北京百姓网免费发布信息
  • 内容电商的网站如何做英文 网站 字体
  • 公司英文网站wordpress文章列表页教程
  • 钓鱼网站如何做施工企业会计核算实务
  • 郑州做网站公司汉狮网公司做网站的多吗
  • 网站设计专业的公司网站建设页面页脚怎么设置
  • 做淘宝店招的网站软文营销的优势
  • 怎样提升网站流量网络建站网网络推广
  • 孝昌建设局网站网络营销网站建设诊断报告
  • 贵州省建设部网站网站建设开发收费
  • 政协信息化网站建设的请示龙华做企业网站
  • 教你如何建网站私域商城平台
  • 做网站需要的图片郑州做网站 熊掌号
  • h5调用小程序api做网站排名优化是怎么回事
  • 网站界面设计的表现wordpress 有赞云