单身狗,在一个整型数组中,只有一个数字出现一次,其他数组都是成对出现的,请找出那个只出现一次的数字

本文介绍如何通过位运算(异或)在C++中找出数组中只出现一次的数字,如给定数组123451234,5是唯一出现一次的数字。作者通过遍历数组并用异或操作记录出现次数。
摘要由CSDN通过智能技术生成

        题解分析:一个数组中数字都是成对出现的,找出只出现一个的数字,此时有两个条件,成对出现 以及一个只出现一次,很显然从成对出现这个条件下手会简单很多,在此之前引进一个位运算符号^(按位异或), a^b相同位为0,相异为1  注:(a ^ a = 0  a ^ 0 = a)

举例:{a, b, c, d, a, b, c}      d只出现了一次

a ^ b ^ c ^ b = a^c

1 ^ 2 ^3 ^ 2 = 1 ^ 3 

执行代码:

//数组中有:1 2 3 4 5 1 2 3 4,只有5出现一次,其他数字都出现2次,找出5
#include <stdio.h>
int main()
{
	int a[] = { 1,2,3,4,5,1,2,3,4 };
	int sz = sizeof(a) / sizeof(a[0]);   //数组的大小
	int med = 0;   //记录出现一次的数字
	for (int i = 0; i < sz; i++)   //遍历数组
	{
		med ^= a[i];
	}
	printf("%d", med);
}

(今天分享就到这里,感谢支持,有啥问题欢迎评论区留言,大家一起探讨!!!)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

糟糕喔

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值