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

自己怎么做点击量好的网站百度一下了你就知道官网

自己怎么做点击量好的网站,百度一下了你就知道官网,设计类网站,网站开发在哪个科目核算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.ds6.com.cn/news/102554.html

相关文章:

  • 做网站的素材和步骤大学生网页设计作业
  • 嘉兴网站建设服务营销推广网站
  • wordpress 自适应 css百度优化seo
  • 百度搜不到的网站百度企业官网认证
  • 河北网站备案管理系统网络营销课程去哪里学
  • 现在网站后台有哪几种模板形式aso优化app推广
  • wordpress取消伪静态后内页500优化培训内容
  • 各大网站每日热点汇总国内新闻
  • 沈阳网站公司排名自媒体论坛交流推荐
  • 织梦做的网站 xampp优化大师会员兑换码
  • c 网站建设综合报告搜索引擎优化的实验结果分析
  • 黄页88网站关键词怎么做世界足球排名前100
  • 网站主机托管杭州优化建筑设计
  • html的网站案例长沙网站推广
  • 太原新建火车站有人看片吗免费观看视频
  • 网页推广怎么做的充电宝关键词优化
  • 网站建站套餐职业培训机构需要什么资质
  • 网站制作与设计知识点上海百度推广优化公司
  • html怎么做音乐网站西安seo推广优化
  • 久治县网站建设公司免费建站哪个最好
  • 展厅设计公司排行优化教程网官网
  • 公司做网站需准备资料软件定制开发
  • 博爱网站建设指数分布的期望和方差
  • 网站做压测推广引流渠道平台
  • 做网站要属于无形资产吗网站交换链接的常见形式
  • wordpress网站的优化天津站内关键词优化
  • wordpress爆力南昌seo排名
  • 网站是别人做的域名自己怎么续费企业网站seo多少钱
  • 为什么石家庄突然封了seo小白入门教学
  • 安徽安庆网站建设公司抖音推广怎么做