求整数数组里的两个非重复整数

问题:一个整数数组里除了两个数之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。要求时间复杂度为O(n), 空间复杂度为O(1).(2012百度)

#include<iostream>
using namespace std;

int findFirst1(int num)
{
	int n=0;
	while((num&1)==0&&n<32)
	{
		num=num>>1;
		n++;
	}
	return n;
}
bool is_1(int num, int count)
{
	num=num>>count;
	return (num&1);
}
void FindNumsAppearOnce(int A[],int length, int &num1, int &num2)
{
	if(length<2)return;
	int res=0;
	for (int i=0;i<length;i++)
	{
		res^=A[i];
	}
	int count=findFirst1(res);
	for (int i=0;i<length;i++)
	{
		if (is_1(A[i], count))
		{
			num1^=A[i];
		}
		else
		{
			num2^=A[i];
		}
	}
}
int main()
{
	int A[]={1, 2, 7, 8, 1, 7, 10, 5, 8, 10};
	int n=sizeof(A)/sizeof(int);
	int num1=0, num2=0;
	FindNumsAppearOnce(A, n, num1, num2);
	cout<<"num1="<<num1;
	cout<<"num2="<<num2;
	return 0;
}

  

时间: 2024-10-25 23:16:48

求整数数组里的两个非重复整数的相关文章

java实现求一个数组里最大值和最小值之前缺省的数的算法

问题描述: 求一个数组里最大值和最小值之间缺省的数,例如 int arrDemo = {1, 3, 7};  那么就要输出最小值1和最大值7之间缺少的数字2,4,5,6 代码如下,有更好的思路欢迎大家在评论区留言讨论 1 package test; 2 3 public class Test { 4 5 static int[] array = { 6 -10,0,3,3,9 7 }; 8 9 private static void printEmptyItems(int[] array) {

给一个整数数组,找到两个数使得他们的和等于一个给定的数 target。

描述 给一个整数数组,找到两个数使得他们的和等于一个给定的数 target. 你需要实现的函数twoSum需要返回这两个数的下标, 并且第一个下标小于第二个下标.注意这里下标的范围是 0 到 n-1. 你可以假设只有一组答案. 样例 Example1: 给出 numbers = [2, 7, 11, 15], target = 9, 返回 [0, 1]. Example2: 给出 numbers = [15, 2, 7, 11], target = 9, 返回 [1, 2]. 1 /** 2 *

C语言实现一个int类型数组里除了两个数字之外,其他的数字都出现了两次,找出这两个数字

题目是这样叙述的:在一个数组中除两个数字只出现1次外,其它数字都出现了2次, 要求尽快找出这两个数字. 要求:时间复杂度为O(N),空间复杂度为O(1). 请看我的分析:将这道题简单化:一个数组中只有一个数字出现一次,其他数字都是成对出现的,这时我们可以根据异或运算符的特性:A^B^A = B; 0 ^ A = A:我们可以将这个数组的全部元素依次做异或运算,最终结果就是那个只出现一次的数字.不会的可看本人(2019-04-04)那天的博客 如果这个数组中出现两个不同的数字,而其他数字均出现两次

算法题:找出整数数组中两个只出现一次的数字

问题:一个整数数组里除了两个数字之外,其他的数字都出现了两次.请写程序找出这两个只出现一次的数字.要求时间复杂度为O(n),空间复杂度为O(1). 分析:这是一个很新颖的关于位运算的题目. 首先考虑这个问题的一个简单版本:一个整数数组里除了一个数字之外,其他的数字都出现两次,请写程序找出这个只出现一次的数字. 这个问题的突破口在哪?题目中数组的性质是只有一个整数出现一次,其他的都出现两次.这样的话就使我们想到了异或运算的性质:任何一个数字异或它自己都等于0.也就是说如果从头到尾依次异或数组中的每

js 数组里求最大值和最小值

// 数组里相邻两个数做比较 取满足条件的那个(以此类推) var arr = [1,3,4,5,6,7]; function Max(array){ var max = array[0]; for(var i=0; i<array.length; i++){ if(max<array[i]) max = array[i]; } return max; } console.log(Max(arr)); function Min(array){ var min = array[0]; for(v

在O(n)时间复杂度内求无序数组中任意两个元素的最大差值,以及存在的组数

题目描述: 求无序数组中任意两个元素的最大差值,以及存在最大差值的组别数. 输入: 输入包含两行,第一行输入一个整数n:第二行n个正整数,用空格隔开. 输出: 输出为一行,包含最大差值,以及存在组别数. 样例输入: 4 4  1  2  1 输出: 3  2 一种实现代码如下(Java版): 1 import java.util.Scanner; 2 /** 3 * 在O(n)时间复杂度内求无序数组中任意两个元素的最大差值,以及存在的组数 4 * @author JiaJoa 5 * 6 */

(笔试题)最小的非“重复的数”

题目: 给一个定义:对一个整数,若其中存在相邻两位上的数字相同,则称其为“重复的数”:现给定一个正整数n,求不小于n的最小的非“重复的数”. 思路: 假设输入的数为n,则令m=n, 分别取m的最低两位数字a,b, 判断是否a==b,如果是说明是重复的数,那么递归调用n=m+1;考虑特殊情况,ab=99,产生进位后100仍未重复数,此时应该递归调用n=m+2: 如果a!=b,则往前挪一位,即m=m/10,直至m/10=0为止,最后返回n. 该思路也可以通过非递归来实现,详见代码. 代码: #inc

位运算-异或运算-只出现一次的数字-给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次。找出那个只出现了一次的元素

给定一个非空整数数组,除了某个元素只出现一次以外,其余每个元素均出现两次.找出那个只出现了一次的元素. 示例: 输入: [2,2,1] 输出: 1 输入: [4,1,2,1,2] 输出: 4 GO: func singleNumber(nums []int) int { var num int for i := 0; i < len(nums); i++ { num = num ^ nums[i]; } return num; } PHP: class Solution { /** * @par

整数数组求最大子数组和

一.实验题目 返回一个整数数组中最大子数组的和. 二.实验要求 输入一个一维整形数组,数组里有正数也有负数. 一维数组首尾相接,象个一条首尾相接带子一样. 数组中连续的一个或多个整数组成一个子数组,每个子数组都有一个和.求所有子数组的和的最大值. 三.设计思想 该实验大部分可以分为两部分: 1.利用while循环录入输入的数组值,输入值为string类型,利用Integer.parseInt(String a),存入int数组,如果是"#"则结束录入 2.调用求最大值函数和的最大值,分