24小时热门版块排行榜    

查看: 2193  |  回复: 8
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

SmallWarm

新虫 (初入文坛)

[交流] 关于求N个无序数中第K大的数。 已有2人参与

昨天去面试,有一题是要求求N个无序数中第K大的数。当时灵感激发,突然想到了快速排序,后来在百度上面一查,已有这种算法。但是,这里还是写下来,大家分享一下。
/*类似于快排的一次排序*/
int fun(int a[],int n,int k) /*n个数的个数,k为所要求的第几大的数*/
{
int key=a[k-1];
int i=0,j=n-1;
while(i!=k-1&&j!=k-1)
{
while(i while(j>k-1&&a[j]>key) j--;
exchange(a,a[j]);
}
if(i=k-1)
{
while(j!=k-1)
{
while(j>k-1&&a[j]>key) j--;
exchange(key,a[j]);
}
}
if(j=k-1)
{
while(i!=k-1)
{
while(i>k-1&&a>key) i++;
exchange(key,a);
}

}
return key;
}


void exchange(int a,int b) /* 交换a,b的值*/
{
a=a+b;
b=a-b;
a=a-b;
}
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

SmallWarm

新虫 (初入文坛)


余泽成: 金币+1, 鼓励交流! 2012-03-23 16:40:32
引用回帖:
3楼: Originally posted by lijie169 at 2012-03-17 10:45:08:
楼主 你确定你运行过么?

在网吧写的,测试都没测试过。我说的只是一种算法...
6楼2012-03-18 17:40:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 9 个回答

lurencyj

木虫 (著名写手)



感谢分享~~
很女子很弓虽大
2楼2012-03-16 17:54:30
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lijie169

铜虫 (著名写手)


小木虫: 金币+0.5, 给个红包,谢谢回帖
楼主 你确定你运行过么?
3楼2012-03-17 10:45:08
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lijie169

铜虫 (著名写手)


余泽成: 金币+1, 鼓励交流! 2012-03-23 16:40:10
我怎么感觉运行不了呢 编译应该就通不过,exchange 是两个整形数,你调用的确实地址和整形
4楼2012-03-17 10:46:27
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通表情 高级回复 (可上传附件)
信息提示
请填处理意见