24小时热门版块排行榜    

查看: 2188  |  回复: 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的回帖

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的回帖

lijie169

铜虫 (著名写手)

★ ★
小木虫: 金币+0.5, 给个红包,谢谢回帖
余泽成: 金币+1, 鼓励交流! 2012-03-23 16:40:19
代码太多了,用快速排序 递归查找还是比较少和快的
5楼2012-03-17 10:48:18
已阅   回复此楼   关注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的回帖

lijie169

铜虫 (著名写手)

★ ★
小木虫: 金币+0.5, 给个红包,谢谢回帖
余泽成: 金币+1, 鼓励交流! 2012-03-23 16:40:43
写算法就写想法或者伪代码,你写的这个有点"四不像"
7楼2012-03-19 17:07:48
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

lurencyj

木虫 (著名写手)

★ ★ ★
小木虫: 金币+0.5, 给个红包,谢谢回帖
余泽成: 金币+2 2012-03-23 16:40:52
我第一次碰到这个算法是在我老婆用的算法书上瞄到的。

《Data Structures & Algorithm Analysis in C++》2ed (影印版)
中文名《数据结构与算法分析C++描述》, 清华大学出版社
作者: Mark Allen Weriss

Chapter 7 Sorting, 7.7.6小节, 基于快速排序法的快速选择算法的平均时间复杂度是O(N),线性的。
很女子很弓虽大
8楼2012-03-19 17:18:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

SmallWarm

新虫 (初入文坛)

引用回帖:
8楼: Originally posted by lurencyj at 2012-03-19 17:18:45:
我第一次碰到这个算法是在我老婆用的算法书上瞄到的。

《Data Structures & Algorithm Analysis in C++》2ed (影印版)
中文名《数据结构与算法分析C++描述》, 清华大学出版社
作者: Mark Allen Weris ...

读书的时候不努力啊,都没看过这本书...
9楼2012-03-19 19:28:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 SmallWarm 的主题更新
普通表情 高级回复 (可上传附件)
信息提示
请填处理意见