ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

在一个数组中找到两个单身狗

2021-10-04 12:03:36  阅读:142  来源: 互联网

标签:sz arr 单身 num2 找到 pos ret int 数组


#include<stdio.h>
//题目要求找出数组中的两个单身狗,即数组中只有两个元素是单独不一样的,别的都是有相同的兄弟
void Find(int arr[], int sz, int *px, int *py){
	//1.把所有位都异或,可以找到那个3
	int i = 0;
	int ret = 0;
	for (i = 0; i < sz; i++){
		ret ^= arr[i];
	}//这就找到了5^6的值3,
	//2 计算ret的哪一位是1
	int pos = 0;
	for (i = 0; i < 32; i++){
		//i表示的是二进制的某一位,某一位与1相与,就还可以知道每一位是否是1
		if ((ret >> i) & 1 == 1){
			pos = i;//pos表示二进制的哪一位是1
			break;
		}
	}
    //把数组低到高的pos位为1的放在一起,把pos位为0的放在一起
	int num1 = 0;
	int num2 = 0;
	for (i = 0; i < sz; i++){
		if ((arr[i] >> pos) & 1 == 1){
			num1 ^= arr[i];//把pos位为1的异或在一起找出单身狗1
		}
		else {
			num2^=arr[i];//把0的异或在一起,找出了单身狗2
		}
	}
	*px = num1;//传进x,y的地址,让他们带回来一些值这叫返回型参数
	*py = num2;
}
int main(){
	int arr[] = { 1, 2, 3, 4, 5, 6, 1, 2, 3, 4 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	int x=0;
	int y=0;
	Find(arr, sz, &x, &y);
	printf("%d %d", x, y);
	return 0;
}

 

标签:sz,arr,单身,num2,找到,pos,ret,int,数组
来源: https://blog.csdn.net/m0_56398287/article/details/120602645

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有