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

数组出现一次两个数字_40

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

67710

数组出现一次数字

如果数组一个数字出现一次,其他数字都是成双成对出现,那么我们从头到尾依次异或数组每个数字,最终结果刚好就是那个出现一次数字,因为那些成对出现两次数字全部在异或抵消了。...那么回到我们题目,因为有两个出现一次数字,所以我们可以试着把原数组分成两个数组,使得每个数组包含一个出现一次数字,而其他数字都成对出现两次。...我们还是从头到尾依次异或数组每个数字,那么最终得到结果就是两个出现一次数字异或结果。...由于这两个数字不一样,所以异或结果至少有一位为1,我们在结果数字中找到第一个为1位置,记为index位,现在我们以第index位是不是1为标准把原数组拆分成两个数组第一个数组数组第index...位都为1,第二个子数组数组第index位都为0,那么出现一次数字将被分配到两个数组中去,于是每个子数组包含一个出现一次数字,而其他数字都出现两次。

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

找出数组出现一次数字

一个数组,有一个数字出现一次,其余数都出现两次,求出那个单独数 可以使用异或或来解决这个问题,因为两个相同数异或之后就是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[]

57430

每日一题《剑指offer》数组篇之数组出现一次两个数字

今日题目链接:数组出现一次两个数字 数组出现一次两个数字 难度:中等 描述 一个整型数组里除了两个数字出现一次,其他数字都出现了两次。请写程序找出这两个出现一次数字。...因此,我们从头到尾依次异或数组每个数字,那么最终结果刚好是那个出现一次数字,重复数字在异或过程中被抵消了。 这是一种比较巧妙思路,然而,本题出现一次数字两个,简单异或无法解决。...具体思路是:我们首先仍然从前向后依次异或数组数字,那么得到结果是两个出现一次数字异或结果,其他成对出现数字被抵消了。...接下来, 以第n位是不是1为标准,将数组分为两个数组,  第一个数组第n位都是1,第二个数组第n位都是0。这样,便实现了我们目标。最后,两个数组分别异或则可以找到出现一次数字。...接下来只要分别两个数组求异或,就能找到第一个数组出现一次数字是6,而第二个子数组出现一次数字是4。

17420

数组重复数字

题目描述 在一个长度为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位置上数字不相等,就把第

2K30

剑指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]); } } //每组就只有一个出现一次数字

31630

剑指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二进制

26930

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

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

29420

数组重复数字

"""描述在一个长度为n数组所有数字都在0到n-1范围内。 数组某些数字是重复,但不知道有几个数字是重复。也不知道每个数字重复几次。请找出数组任意一个重复数字。...例如,如果输入长度为7数组[2,3,1,0,2,5,3],那么对应输出是2或者3。...存在不合法输入的话输出-1数据范围:0\le n \le 10000 \0≤n≤10000进阶:时间复杂度O(n)\O(n) ,空间复杂度O(n)\O(n)示例1输入:[2,3,1,0,2,5,3]复制返回值...:2复制说明:2或3都是对数据范围:0\le n \le 10000 \0≤n≤10000进阶:时间复杂度O(n)\O(n) ,空间复杂度O(n)\O(n)"""# @param numbers int...整型一维数组# @return int整型#from typing import Listclass Solution: def duplicate(self , numbers: List[int

1.4K10

查找数组重复数字

题目来源于《剑指Offer》面试题3:找出数组重复数字。   // 题目:在一个长度为n数组所有数字都在0到n-1范围内。...数组某些数字是重复,但不知道有几个数字重复了,   // 也不知道每个数字重复了几次。请找出数组任意一个重复数字。...: (输出) 数组一个重复数字 // 返回值: // true - 输入有效,并且数组存在重复数字 // false - 输入无效,或者数组没有重复数字...,通过指针可以访问和修改指向对象,但是拷贝指针是两个不同指针 // // 建议使用引用类型形参替代指针 // if (numbers == nullptr || length <=...numbers, sizeof(numbers) / sizeof(int), duplications, sizeof(duplications) / sizeof(int), true); } // 数组存在多个重复数字

3.9K60

寻找数组重复数字

规则如下: 给定一个长度为n数组数组每个元素取值范围为:0~n-1 数组某些数字是重复,但是不知道哪些数字重复了,也不知道重复了几次 求数组任意一个重复数字 实现思路 这个问题实现思路有三种...排序方法实现 用排序方法实现分为两步: 先用快速排序对数组进行排序 遍历排序好数组,如果其相邻两个元素相等就代表数组中有重复数字,将其返回即可。 接下来,我们通过一个例子来验证下上述思路。...返回找到重复数字 时间复杂度分析:遍历数组,判断哈希表是否包含当前遍历到元素时,都可以用O(1)时间复杂度完成,所有元素遍历完就需要n个O(1),因此总时间复杂度为O(n) 空间复杂度分析:...动态排序法实现 根据题意可知,数组中元素取值范围在0~n-1,那么就可以得到如下结论: 如果数组没有重复元素,那么第i号元素值一定是当前下标(i) 如果数组中有重复元素,那么有些位置可能存在多个数字...(let i = 0; i < sortArray.length; i++) { // 排序完成后,相邻两个数字相等就代表数组中有重复数字,将其返回

1.3K10
领券