#include<stdio.h>
int main()
{
int arr[] = { 1, 1, 2, 2, 3, 4, 5, 5 };
int i = 0;
int j = 0;
int flag = 0;
for (i = 0; i < sizeof(arr) / sizeof(arr[0]); i++)
{
flag = 0;
for (j = 0; j < sizeof(arr) / sizeof(arr[0]); j++)
{
if ((arr[i] == arr[j])&&(j != i)) // j != i 这个条件是为了避免这个数字与自己比较一次
{
flag = 1;
}
}
if (flag == 0)
{
printf("%d ", arr[i]);
}
}
system("pause");
return 0;
int main()
{
int arr[] = { 1, 1, 2, 2, 3, 4, 5, 5 };
int i = 0;
int j = 0;
int flag = 0;
for (i = 0; i < sizeof(arr) / sizeof(arr[0]); i++)
{
flag = 0;
for (j = 0; j < sizeof(arr) / sizeof(arr[0]); j++)
{
if ((arr[i] == arr[j])&&(j != i)) // j != i 这个条件是为了避免这个数字与自己比较一次
{
flag = 1;
}
}
if (flag == 0)
{
printf("%d ", arr[i]);
}
}
system("pause");
return 0;
}
接下来有这个问题的简化版:一组数据中只有一个数字出现了一次,其他所有数字都是成对出现的,找出这个数字。
这个问题使用位运算将很简单:
int main()
{
int a[] = { 11,11,25,2,2 };
int i = 0;
int b = 0;
for (; i < sizeof(a) / sizeof(a[0]); i++)
{
b ^= a[i];
}
printf("%d", b);
system("pause");
return 0;
}
两个数相等异或结果为0,最后异或完的结果就是只出现一次的数字了。