杭电oj find your present (2)

<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">我之前写的是</span><span style="font-family: Arial, Helvetica, sans-serif; color: green; background-color: rgb(255, 255, 255);">Memory Limit Exceeded,但是感觉方法很对,运行结果也很正确。</span>

//此思路是:设总个数是n ,从第一个数开始,分别与其它数进行比较,如果不同的话,count++(count初值为0),如果相同的话,直接break(判断下一个数,与其它数的关系)。如果此数与其它数比完了,count==n-1,说明此数是独一无二的一个,输出来即可,根据题意,就不用再进行下一个数的判断了,加上break。

代码是:

#include<iostream>
#include<stdio.h>
using namespace std;
int a[1000000];
int main()
{
	int i,j,n,count;
	while(scanf("%d",&n),n)
	{
		for(i=0;i<n;i++)
			cin>>a[i];
		for(i=0;i<n;i++)
		{	
			count=0;
			for(j=0;j<n;j++)
			{
				if(i!=j &&a[i]!=a[j])
				{
					count++;
				}
				if(i!=j &&a[i]==a[j])
					break;
			}
			if(count==n-1)
			{
				printf("%d
",a[i]);
				break;
			}
		}
	}
	return 0;
}
出现这种原因应该是数组定义的过长,循环次数太多造成的。百度了一下,这道题,是算异或的。。输入的每个数都按位异或起来,得到的结果就是不同的那个数。(昨天改这个程序的时候,我又定义了数组a,长度是1000000的,直接可一次性的输入,但是又是Memory Limit Exceeded,  让陈涛涛看一下,他说,可以一个一个输入,输入一个,异或的结果放到result里……最后正确了……

异或怎么算,http://blog.csdn.net/tangyanzhi1111/article/details/21696943  这里面介绍很详细。。

此题正确的代码:

#include<iostream>
#include<stdio.h>
using namespace std;
int main()
{
	int n,i,a;
	while(scanf("%d",&n),n)
	{
		int result=0;
		while(n--)
		{
			cin>>a;
	 	  result=result^a;
		}
	    printf("%d
",result);
	}
	return 0;
}






原文地址:https://www.cnblogs.com/NYNU-ACM/p/4236804.html