杭电oj find your present (2)
2024-08-25 11:32:13
<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;
}
最新文章
- linux管道命令grep命令参数及用法详解---附使用案例|grep
- [转]IE8兼容Object.keys
- vue在多级联动时,一些情况不用watch而用onchange会更好
- filter,map,reduce,lambda(python3)
- @ModelAttribute运用详解
- spinner下拉列表
- 【转】【Thread】ReaderWriterLock 读写锁
- Ruby界面开发--wxRuby库TextCtrl相关问题
- JavaScript调试技巧之console.log()详解
- sql 基本操作
- UML: CIM &; PIM
- linux修改主机名(hostname)转载
- Linux企业级项目实践之网络爬虫(17)——存储页面
- C++ 中 struct和class 的区别
- POJ 3579 Median(二分答案+Two pointers)
- [WPF疑难] 继承自定义窗口
- APP生产流程图片解说
- smarty模板基础知识
- Excel坐标自动在AutoCad绘图_6
- 《Web接口开发与自动化测试 -- 基于Python语言》---现已出版。
热门文章
- Intellij IDEA + Android SDK + Genymotion Emulator打造最佳Android开发
- CCNA实验(9) -- Frame Relay
- HDU 2588 GCD
- aliyun opts 集锦
- 2015 11 26 java 配置环境变量
- URAL 1297 Palindrome 后缀数组
- C++重载赋值运算符
- 循环-10. 求序列前N项和(15)
- IOS 表视图(UITableVIew)的使用方法(5)表视图的编辑功能(删除)
- LintCode-最长公共子串