标题:怎样用6次比较在5个元素中找到中位数
只看楼主
zhongliangv
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2010-10-30
结帖率:50%
已结贴  问题点数:20 回复次数:5 
怎样用6次比较在5个元素中找到中位数
用算法或中文说一下方法即可,谢谢
搜索更多相关主题的帖子: 中位数 元素 
2010-11-05 08:41
五当家
Rank: 12Rank: 12Rank: 12
等 级:火箭侠
威 望:2
帖 子:1112
专家分:3674
注 册:2010-10-20
得分:5 
如果用数组的话,可以先输入5个数.然后按从小到大,或从大到小顺序排序.然后输出第三个元素就是.

经验积累中............
2010-11-05 12:17
自由战士89
Rank: 5Rank: 5
等 级:职业侠客
帖 子:154
专家分:387
注 册:2010-9-2
得分:5 
有个相似的贴,5个元素,如WMDJT,先排前三个后为DMW,比较3次,再将J二分插入后为DJMW,又比较2次.最后一个T元素只需与中间两个数比较既可得到中间的数.共用7次比较.
2010-11-05 14:59
自由战士89
Rank: 5Rank: 5
等 级:职业侠客
帖 子:154
专家分:387
注 册:2010-9-2
得分:0 
有个相似的贴,5个元素,如WMDJT,先排前三个后为DMW,比较3次,再将J二分插入后为DJMW,又比较2次.最后一个T元素只需与中间两个数(JM)比较既可得到中间的数.共用7次比较.
2010-11-05 15:00
帝国
Rank: 3Rank: 3
来 自:云南昆明
等 级:论坛游侠
帖 子:68
专家分:144
注 册:2010-10-11
得分:5 
你的两个帖子是相同的问题,5数排序需要8次比较,除非先能解决你先前的提问,5个数排序使用7次比较才有可能回答你这个帖子的问题。但是目前我实在无法想出可行的算法,目前多数排序最快的就是使用二叉树了。
2010-11-05 15:10
落拓
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:58
专家分:173
注 册:2010-9-29
得分:5 
可以用一个比较浪费内存的方法。
#include<stdio.h>
#include<malloc.h>
#include<math.h>
main()
{
    int a[5],i=0,n,m=0,k,*p;
     
    while(i<5)
        scanf("%d",&a[i++]);//输入五个数

    for(i=0,n=0;i<5;i++,n=0)
    {
        for(k=a[i];k;n++)
          k/=10;
        
        if(n>m) m=n;
    }

   n=(int)pow(10,m);
 
   p=(int *)malloc(n*sizeof(int));
   
   for(i=0;i<n;i++)
       p[i]=0;
 
   for(i=0;i<5;i++)
   {m=a[i];
       p[m]=a[i];
   }

   for(i=0,k=1;k<=3;i++)
       if(p[i]) k++;

    printf("%d",p[i-1]);
}
2010-11-05 18:01



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-325025-1-1.html




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

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