|
网站首页
|
业界新闻
|
小组
|
威客
|
人才
|
下载频道
|
博客
|
代码贴
|
在线编程
|
编程论坛
|
登录
注册
短消息
我发表的主题
我参与的主题
我收藏的贴子
我上传的附件
我下过的附件
编辑个人资料
我的博客
用户控制面板
搜索
道具
恢复默认风格
碧海青天
秋意盎然
棕红预览
粉色回忆
蓝雅绿
紫色淡雅
青青河草
e点小镇
橘子红了
红红夜思
水晶紫色
雪花飘飘
新年快乐
风格
短消息
论坛展区
帮助
编程论坛
→
开发语言
→
『 C语言论坛 』
→ 怎样用6次比较在5个元素中找到中位数
我的收件箱(0)
欢迎加入我们,一同切磋技术
用户名:
密 码:
共有
865
人关注过本帖
标题:
怎样用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
快速回复:
怎样用6次比较在5个元素中找到中位数
数据加载中...
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.045000 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved