首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

数组中只出现一次的数字

如果数组中只一个数字是只出现一次的,其他数字都是成双成对出现的,那么我们从头到尾依次异或数组中的每个数字,最终的结果刚好就是那个只出现一次的数字,因为那些成对出现两次的数字全部在异或中抵消了。...那么回到我们的题目,因为有两个只出现一次的数字,所以我们可以试着把原数组分成两个子数组,使得每个数组包含一个只出现一次的数字,而其他数字都成对出现两次。...如果这样拆分成两个数组,那么我们就可以按照之前的办法分别对两个数组进行异或运算找出两个只出现一次的数字。 问题来了,如何进行分组呢?...位都为1,第二个子数组中的数组第index位都为0,那么只出现一次的数字将被分配到两个子数组中去,于是每个子数组中只包含一个出现一次的数字,而其他数字都出现两次。...这样我们就可以用之前的方法找到数组中只出现一次的数字了。

90920

找出数组中只出现一次的数字

一个数组中,有一个数字只出现一次,其余的数都出现两次,求出那个单独的数 可以使用异或或来解决这个问题,因为两个相同的数异或之后就是0,0与一个数异或还是这个数,而且异或满足交换律 public static...n ^= arr[i];//与sun+=arr[i]类似,方便理解 } System.out.println(n); } 拓展: 一个数组中...,只有两个不同的数字出现一次,其余的数都出现两次,求出那两个只出现一次的数 思路:假设数组是{1,2,3,1},要想找到那两个只出现一次的数,只需要将数组里面所有的数字异或一下,得到结果sum,然后将...sum进行移位操作判断是否为1,如果不为1,依次往后,知道右移到位为1的时候为止,其实就是确定sum从右往左数第几位是1,从而起到筛选的作用, 接下来将数组遍历一遍,判断数组中的每个数是否满足移k位结果是否为...,所以在异或一个num1就可以得到num2 总结:简单来说,就是通过移位操作来达到分类的作用,接下来就是使用之前异或的方法即可 代码如下 public static int[] Search(int[]

60530
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    剑指offer 数组中只出现一次的数字

    题目描述 一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。...解题思路 我们利用异或的特性,异或两个相同的数字的结果为零,第一遍对数组进行异或的结果是 两个只出现一次的数字的异或值(a^b),并不是我们想要的,所以我们根据这个异或值找到一位为1的位数 (a和b的这个位上的值肯定是不相同的...),按照原始数组中所有数字的这个位是否为1分成两组,这样两组里面有且仅有一个只出现一次的数字,然后再次异或,就能得到a和b 代码 class Solution { public: void FindNumsAppearOnce...(vector data,int* num1,int *num2) { //对数组中的数字进行异或 int xorresult=data[0];...}else{ isone.push_back(data[i]); } } //每组就只有一个只出现一次的数字了

    34630

    数组中只出现一次的数字----异或的运用

    题目描述 一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。...方法一:遍历数组,第一次遍历的直接存入list,第二次再遍历到了就移除,将剩下的两个元素填到数组里; public void FindNumsAppearOnce(int [] array,int...0^X=X 此题用了两次异或运算特点: (1)第一次使用异或运算,得到了两个只出现一次的数相异或的结果。 (2)因为两个只出现一次的数肯定不同,即他们的异或结果一定不为0,一定有一个位上有1。...另外一个此位上没有1,我们可以根据此位上是否有1,将整个数组重新划分成两部分,一部分此位上一定有1,另一部分此位上一定没有1,然后分别对每部分求异或,因为划分后的两部分有这样的特点:其他数都出现两次,只有一个数只出现一次...因此,我们又可以运用异或运算,分别得到两部分只出现一次的数。

    43220

    数组中只出现一次的两个数字_40

    题目描述 一个整型数组里除了两个数字只出现一次,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。...示例1 输入 [1,4,1,6] 返回值 [4,6] 说明 返回的结果中较小的数排在前面 思路: 1.首先全数组异或找出这个数组中不同的两个数字的异或结果 initNum 原理:相同数字的异或结果为0...,利用两个数字在此位置上必然是一个是0一个是1,我们可以利用与特性区分这两个数字的位置.另外其他相同数字不管落在数组中哪个位置上,两个相同数字的异或结果必然是0,因此最后落到我们数组中的必然两个不同的数字...//先亦或一波,求出数组中只出现过一次的数字的亦或结果 int initNum=array[0]; for (int i = 1; i 的是只出现过一次的且&one等于0的; if ((one&array[i])==0){ res[0]^=array[i]

    71710

    剑指40-数组中只出现一次的数字

    位运算、哈希表 题目描述 一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。...解法1 遍历数组,用map保存出现的次数,再找到次数为1的数 class Solution { public: void FindNumsAppearOnce(vector data,...,那么他们异或的结果为0 所以将所有数字异或,结果就是两个只出现一次的数字异或的结果 那么如何分离这两个数字呢 异或结果为1时,两个数字里对应的位肯定为1和0,所以找到异或结果为1的位置ret...:所有数组异或–>和反码与得到1的位置–>和每个数字与判断–>对应再异或 class Solution2 { public: void FindNumsAppearOnce(vector<int...) { int ret = 0; for (const int k : data) ret ^= k; ret &= (-ret); //找ret二进制中为

    28930

    剑指Offer-数组中只出现一次的数字

    题目描述 一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。...思路 思路一: 利用HashSet的元素不能重复,如果有重复的元素,则删除重复元素,如果没有则添加,最后剩下的就是只出现一次的元素 思路二: 用HashMap保存数组的值,key为数组值,value为布尔型表示是否有重复...package Array; import java.util.HashMap; import java.util.HashSet; import java.util.Iterator; /** * 数组中只出现一次的数字...* 一个整型数组里除了两个数字之外,其他的数字都出现了两次。...请写程序找出这两个只出现一次的数字。 * num1,num2分别为长度为1的数组。

    79660

    剑指Offer(四十)-- 数组中只出现一次的数字

    题目描述 一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。...遍历里面所有的数字,如果hashmap中存在,那么value(次数)+1,如果hashmap中不存在,那么value置为1。...遍历完成之后,需要将次数为1的数字捞出来,同样是遍历hashmap,由于只有两个满足条件,我们设置一个标识变量,初始化为1,如果找到第一个满足条件的数字,除了写入放回数组中,还需要将该标识置为2,表示接下来找的是第...那我们取出异或结果res最低位的1,假设这个数值是temp(temp只有一个位是1,也就是A和B最后不同的位) 遍历数组中的元素,和temp进行与操作,如果和temp相与,不等于0。...= 0) { res1 ^= val; } } // 由于其他满足条件的数字都出现两次,所以结果肯定就是只出现一次的数

    31020

    如何检查 Java 数组中是否包含某个值 ?

    参考链接: Java程序检查数组是否包含给定值 作者 |  沉默王二  本文经授权转载自沉默王二(ID:cmower)  在逛 programcreek 的时候,我发现了一些专注细节但价值连城的主题。...比如说:如何检查Java数组中是否包含某个值 ?像这类灵魂拷问的主题,非常值得深入地研究一下。  另外,我想要告诉大家的是,作为程序员,我们千万不要轻视这些基础的知识点。...如何检查数组(未排序)中是否包含某个值 ?这是一个非常有用并且经常使用的操作。我想大家的脑海中应该已经浮现出来了几种解决方案,这些方案的时间复杂度可能大不相同。  ...targetValue);     if (a > 0)         return true;     else         return false; }  不过,binarySearch() 只适合查找已经排序过的数组...这是因为把元素从数组中读出来再添加到集合中,就要花费一定的时间,而简单的 for 循环则省去了这部分时间。

    9.1K20

    在Java中如何高效判断数组中是否包含某个元素

    原文作者:Hollis_Chuang 原文地址:http://www.hollischuang.com/archives/1269 如何检查一个数组(无序)是否包含一个特定的值?...查找有序数组中是否包含某个值的用法如下: public static boolean useArraysBinarySearch(String[] arr, String targetValue) {...基本思想就是从数组中查找某个值,数组的大小分别是5、1k、10k。这种方法得到的结果可能并不精确,但是是最简单清晰的方式。...实际上,如果你需要借助数组或者集合类高效地检查数组中是否包含特定值,一个已排序的列表或树可以做到时间复杂度为O(log(n)),hashset可以达到O(1)。...,他判断一个元素是否包含在数组中其实也是使用循环判断的方式。

    5.2K10

    数组中重复的数字

    题目描述 在一个长度为n的数组里的所有数字都在0到n-1的范围内。 数组中某些数字是重复的,但不知道有几个数字是重复的。也不知道每个数字重复几次。请找出数组中任意一个重复的数字。...例如,如果输入长度为7的数组{2,3,1,0,2,5,3},那么对应的输出是第一个重复的数字2。 解题思路 最简单的就是用一个数组或者哈希表来存储已经遍历过的数字,但是这样需要开辟额外的空间。...如果题目要求不能开辟额外的空间,那我们可以用如下的方法: 因为数组中的数字都在0~n-1的范围内,所以,如果数组中没有重复的数,那当数组排序后,数字i将出现在下标为i的位置。...现在我们重排这个数组,从头到尾扫描每个数字,当扫描到下标为i的数字时,首先比较这个数字(记为m)是不是等于i。...如果是,则接着扫描下一个数字;如果不是,则再拿它和m 位置上的数字进行比较,如果它们相等,就找到了一个重复的数字(该数字在下标为i和m的位置都出现了),返回true;如果它和m位置上的数字不相等,就把第

    2.1K30

    js判断数组中是否包含某个指定元素的个数_js 数组包含某个元素

    indexOf()完整语法: array.indexOf(item,start) //参数: item:必须。查找的元素。 start:可选的整数参数。规定在字符串中开始检索的位置。...它的参数是一个回调函数,所有数组元素依次遍历该回调函数,直到找出第一个返回值为true的元素,然后返回该元素,否则返回undefined。...find() 方法为数组中的每个元素都调用一次函数执行: 当数组中的元素在测试条件时返回 true 时, find() 返回符合条件的元素,之后的值不会再调用执行函数。...) { //则包含该元素 } }) 方法三:array.findIndex() array.findIndex()和array.find()十分类似,返回第一个符合条件的数组元素的位置...findIndex() 方法为数组中的每个元素都调用一次函数执行: 当数组中的元素在测试条件时返回 true 时, findIndex() 返回符合条件的元素的索引位置,之后的值不会再调用执行函数。

    11.3K30
    领券