<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\n",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\n",result);
}
return 0;
}

												

最新文章

  1. linux管道命令grep命令参数及用法详解---附使用案例|grep
  2. [转]IE8兼容Object.keys
  3. vue在多级联动时,一些情况不用watch而用onchange会更好
  4. filter,map,reduce,lambda(python3)
  5. @ModelAttribute运用详解
  6. spinner下拉列表
  7. 【转】【Thread】ReaderWriterLock 读写锁
  8. Ruby界面开发--wxRuby库TextCtrl相关问题
  9. JavaScript调试技巧之console.log()详解
  10. sql 基本操作
  11. UML: CIM &amp; PIM
  12. linux修改主机名(hostname)转载
  13. Linux企业级项目实践之网络爬虫(17)——存储页面
  14. C++ 中 struct和class 的区别
  15. POJ 3579 Median(二分答案+Two pointers)
  16. [WPF疑难] 继承自定义窗口
  17. APP生产流程图片解说
  18. smarty模板基础知识
  19. Excel坐标自动在AutoCad绘图_6
  20. 《Web接口开发与自动化测试 -- 基于Python语言》---现已出版。

热门文章

  1. Intellij IDEA + Android SDK + Genymotion Emulator打造最佳Android开发
  2. CCNA实验(9) -- Frame Relay
  3. HDU 2588 GCD
  4. aliyun opts 集锦
  5. 2015 11 26 java 配置环境变量
  6. URAL 1297 Palindrome 后缀数组
  7. C++重载赋值运算符
  8. 循环-10. 求序列前N项和(15)
  9. IOS 表视图(UITableVIew)的使用方法(5)表视图的编辑功能(删除)
  10. LintCode-最长公共子串