<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; }