找单身狗(c语言)

1./找单身狗

//在一个数组中只有两个数字出现一次,其他所以数字都出现了两次
//编写一个函数找出这两个只出现一次的数字

2.方法一:暴力求解,我们用冒泡函数,进行比较如果i==j,那么n++,如果n==1,那么我们将他存储在arr2[],然后我们将arr2[]进行打印,就可以了。

cs 复制代码
#include<stdio.h>
//方法一;
int main()
{
	int b = 0;
	int n = 0;
	int arr2[2] = { 0 };
	int arr[ ] = { 0,1,2,3,4,5,0,1,2,3 };
	int ret = sizeof(arr) / sizeof(arr[0]);
	for (int i = 0; i < ret; i++)
	{
		int n = 0;
		for (int j = 0; j < ret; j++)
		{
			if (arr[i] == arr[j])
			{
				n++;
			}
		}
		if (n == 1)
		{
			arr2[b] = arr[i];
			b++;
		}
	}
	for (int i = 0; i < b; i++)
	{
		printf("%d ", arr2[i]);
	}
	return 0;
}

3.方法二:

/1.进行分组,如何进行分组

//用按位异或(^)比较二进制的位数,相同等于 0,不同等于 1,
// 因为3^3=0,3^3^5=5,所以可以找到他们单独的数字
//如数组int arr[ ] = { 7,1,2,3,4,5,7,1,2,3 };按位异或就是
//7^1^2^3^4^5^7^1^2^3==7^7^7^1^1^2^2^3^3^4^5==4^5
//4的二进制 0100
//5的二进制 0101
//按位与后为 0001,我们进行取一如果找到了一就出来,如果没有找到n++,
// 不同的数一定能找到一个二进制不同的地方,按位于后为最右边的1
//如果我们找到二进制的第n位为一,我们就可以将4与5分开

cs 复制代码
#include<stdio.h>
void signle_dog(int arr[], int sz,int *pc, int *pb)
{
	int pos = 0;
	int ret = 0;
	//进行按异或
	for (int i = 0; i < sz; i++)
	{
		ret = ret ^ arr[i];
	}
	//求出二进制第几位是一
	for (pos = 0; pos < 32; pos++)
	{
		if (((ret >> pos) & 1) == 1)
		{
			break;
		}
	}
	//将他们进行分组
	for (int j = 0; j < sz; j++)
	{
		if (((arr[j] >> pos) & 1) == 1)
		{
			*pc = *pc ^ arr[j];
		}
		else
		{
			*pb = *pb ^ arr[j];
		}
	}

}
int main()
{
	int arr[] = { 0,1,2,3,4,5,0,1,2,3 };
	int dog1 = 0;
	int dog2 = 0;
	int sz = sizeof(arr) / sizeof(arr[0]);
	signle_dog(arr,sz,&dog1,&dog2);
	printf("%d %d\n", dog1, dog2);
	return 0;
}
相关推荐
坚果派·白晓明6 小时前
【鸿蒙PC三方库移植适配框架解读系列】第八篇:扩展lycium框架使其满足rust三方库适配
c语言·开发语言·华为·rust·harmonyos·鸿蒙
花间相见6 小时前
【PaddleOCR教程01】PP-OCRv5 全面指南:从模型架构到实战部署
开发语言·r语言
X journey6 小时前
机器学习进阶(13):支持向量机SVM
算法·机器学习·支持向量机
小短腿的代码世界7 小时前
Qt 股票订单撮合引擎:高频交易系统的核心心脏
开发语言·数据库·qt·系统架构·交互
洛水水7 小时前
【力扣100题】30.二叉树的直径
算法·leetcode·职场和发展
gihigo19987 小时前
Bezier曲线曲面生成算法
算法
平行侠8 小时前
024多精度大整数 - 突破硬件精度限制的任意精度运算
数据结构·算法
谙弆悕博士8 小时前
快速学C语言——第16章:预处理
c语言·开发语言·chrome·笔记·创业创新·预处理·业界资讯
matlabgoodboy8 小时前
软件开发定制小程序APP帮代做java代码代编写C语言设计python编程
java·c语言·小程序
IronMurphy8 小时前
【算法四十五】139. 单词拆分
算法