标题:[求助]从一个n个元素的数组中寻找第k个最小值
只看楼主
vnimalev
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2007-6-2
 问题点数:0 回复次数:4 
[求助]从一个n个元素的数组中寻找第k个最小值
刚学C,请会GGJJ帮助一下

从一个n个元素的数组中寻找第k个最小值,并输出
搜索更多相关主题的帖子: 元素 
2007-06-02 19:12
老糊涂
Rank: 1
等 级:新手上路
威 望:1
帖 子:117
专家分:0
注 册:2007-5-19
得分:0 
有人刚问过,你找找看

2007-06-02 19:44
Eastsun
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:32
帖 子:802
专家分:0
注 册:2006-12-14
得分:0 
最简单的方法:先将数组排序,然后得到第k个元素就OK了.
ps:不过这个题目有时间复杂度为O(n)的算法

My BlogClick Me
2007-06-02 20:45
风之舞鹤
Rank: 1
等 级:新手上路
帖 子:180
专家分:0
注 册:2007-6-2
得分:0 

#define n 5
main()
{ int a[n],i,j,k,t;
scanf("%d",&k);
printf("请输入n个数:");
for(i=0;i<n;i++)
scanf("%d",&a[i]);
for(i=0;i<n-1;i++)
for(j=i+1;j<n;j++)
if(a[i]>a[j])
{ t=a[i];
a[i]=a[j];
a[j]=t;
}


for(i=0;i<k;i++)
printf("%-3d",a[i]);

}


2007-06-03 09:47
风之舞鹤
Rank: 1
等 级:新手上路
帖 子:180
专家分:0
注 册:2007-6-2
得分:0 

#define n 5
main()
{ int a[n],i,j,k,t;
scanf("%d",&k);
printf("请输入n个数:");
for(i=0;i<n;i++)
scanf("%d",&a[i]);
for(i=0;i<n-1;i++)
for(j=i+1;j<n;j++)
if(a[i]>a[j])
{ t=a[i];
a[i]=a[j];
a[j]=t;
}


printf("%d",a[k-1]);

}


2007-06-03 12:47



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




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

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