搜索
编程论坛
→
开发语言
→
『 C语言论坛 』
→ 怎样用6次比较在5个元素中找到中位数
标题:
怎样用6次比较在5个元素中找到中位数
只看楼主
zhongliangv
等 级:
新手上路
帖 子:6
专家分:0
注 册:2010-10-30
结帖率:
50%
楼主
已结贴
√
问题点数:20 回复次数:5
怎样用6次比较在5个元素中找到中位数
用算法或中文说一下方法即可,谢谢
搜索更多相关主题的帖子:
中位数
元素
2010-11-05 08:41
五当家
等 级:
火箭侠
威 望:
2
帖 子:1112
专家分:3674
注 册:2010-10-20
第
2
楼
得分:5
如果用数组的话,可以先输入5个数.然后按从小到大,或从大到小顺序排序.然后输出第三个元素就是.
经验积累中............
2010-11-05 12:17
自由战士89
等 级:
职业侠客
帖 子:154
专家分:387
注 册:2010-9-2
第
3
楼
得分:5
有个相似的贴,5个元素,如WMDJT,先排前三个后为DMW,比较3次,再将J二分插入后为DJMW,又比较2次.最后一个T元素只需与中间两个数比较既可得到中间的数.共用7次比较.
2010-11-05 14:59
自由战士89
等 级:
职业侠客
帖 子:154
专家分:387
注 册:2010-9-2
第
4
楼
得分:0
有个相似的贴,5个元素,如WMDJT,先排前三个后为DMW,比较3次,再将J二分插入后为DJMW,又比较2次.最后一个T元素只需与中间两个数(JM)比较既可得到中间的数.共用7次比较.
2010-11-05 15:00
帝国
来 自:云南昆明
等 级:
论坛游侠
帖 子:68
专家分:144
注 册:2010-10-11
第
5
楼
得分:5
你的两个帖子是相同的问题,5数排序需要8次比较,除非先能解决你先前的提问,5个数排序使用7次比较才有可能回答你这个帖子的问题。但是目前我实在无法想出可行的算法,目前多数排序最快的就是使用二叉树了。
2010-11-05 15:10
落拓
等 级:
论坛游侠
帖 子:58
专家分:173
注 册:2010-9-29
第
6
楼
得分: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
6
1/1页
1
参与讨论请移步原网站贴子:
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