zoukankan      html  css  js  c++  java
  • 杭电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;
    }



    
    

  • 相关阅读:
    android pcm
    mongo DB的一般操作
    使用SQL Server 扩展事件来创建死锁的时间跟踪
    sql 日期格式汇总
    简述SQL2008部署多实例集群(学习)
    数据库压缩备份提高备份效率
    SSRS报表连接超时的问题
    classLoader.getResourceAsStream中文乱码
    jQuery与js对象互转
    sqlserver判断字段是否存在更改字段
  • 原文地址:https://www.cnblogs.com/NYNU-ACM/p/4236804.html
Copyright © 2011-2022 走看看