| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 515 人关注过本帖
标题:难搞的数字模式
取消只看楼主 加入收藏
蓝桥
Rank: 2
等 级:论坛游民
帖 子:18
专家分:22
注 册:2014-2-26
结帖率:100%
收藏
已结贴  问题点数:10 回复次数:2 
难搞的数字模式
#include<stdio.h>
#include<stdlib.h>
main()
{
    int i,j,n,flag,max=0,result=0,*a;
    scanf("%d",&n);
    a=(int *)malloc(n*sizeof(int));
    for(i=0;i<n;i++)
        scanf("%d",a+i);
    for(i=0;i<n-1;i++)
    {
        flag=0;
        for(j=i;j<n;j++)
        {
            if(a[i]==a[j])
                flag++;
        }
        if(flag>max)
        {
            max=flag;
            result=a[i];
        }
        if(flag==max && a[i]<result)
            result=a[i];
    }
    printf("%d\n",result);
    return 0;
}
运行结果是Time Limit Exceeded,算法应如何改改?
搜索更多相关主题的帖子: include result 
2014-02-27 00:05
蓝桥
Rank: 2
等 级:论坛游民
帖 子:18
专家分:22
注 册:2014-2-26
收藏
得分:0 
Description   数字的模式是指在一堆给定数字中出现次数最多的数值,如5,5,5,3,3,2,6,4,它的模式就是5。现在你的任务,就是从数字中找到它的模式.
Input   第一行为整数N.从第二行开始为N个整数。对于输入的每个数,有( |input_number| <= 2000000 ).Output   输出这些数字的模式,如果模式个数不为1,选择它们之中较小的。
Sample Input

10
1 2 3 4 5 6 7 8 9 9


Sample Output

9
这是原题
2014-02-28 00:12
蓝桥
Rank: 2
等 级:论坛游民
帖 子:18
专家分:22
注 册:2014-2-26
收藏
得分:0 
很感谢楼上的代码,,可是运行结果都是wrong answer,另外,此题需要输入值
我的代码结果正确,可时间复杂度太大,有没有更好的实现方法??
2014-02-28 22:22
快速回复:难搞的数字模式
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.018784 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved