免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 3530 | 回复: 10
打印 上一主题 下一主题

[算法] 算法问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-09-19 15:18 |只看该作者 |倒序浏览
写一段程序,找出数组中第k大小的数,输出数所在的位置。例如{2,4,3,4,7}中,第一大的数是7,位置在4。第二大、第三大的数都是4,位置在1、3随便输出哪一个均可。函数接口为:int find_orderk(const int* narry,const int n,const int k)
要求算法复杂度不能是O(n^2)

论坛徽章:
0
2 [报告]
发表于 2007-09-19 15:28 |只看该作者
1. 利用求中位数的方法求出第k大的数
递归,会用到qsort时用到的partition函数
时间复杂度O(n)
2. 在原数组中查找它的位置
时间复杂度O(n)

[ 本帖最后由 ypxing 于 2007-9-19 15:30 编辑 ]

论坛徽章:
0
3 [报告]
发表于 2007-09-19 15:35 |只看该作者
最屁的数组遍历一遍也就O(n)了,题设的O(n^2)等于没有限制。

论坛徽章:
0
4 [报告]
发表于 2007-09-19 15:37 |只看该作者
应该不是吧

原帖由 NewCore 于 2007-9-19 15:35 发表
最屁的数组遍历一遍也就O(n)了,题设的O(n^2)等于没有限制。

论坛徽章:
0
5 [报告]
发表于 2007-09-19 15:40 |只看该作者

回复 #4 ypxing 的帖子

不好意思,纠正一下

应该说最坏的情况下的时间复杂度也就O(n^2)

论坛徽章:
0
6 [报告]
发表于 2007-09-20 08:35 |只看该作者

回复 #1 1980116 的帖子

高手过来指点一下啊,我感觉这些答案都不合要求

论坛徽章:
0
7 [报告]
发表于 2007-09-20 08:42 |只看该作者
为什么呢?

原帖由 1980116 于 2007-9-20 08:35 发表
高手过来指点一下啊,我感觉这些答案都不合要求

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
8 [报告]
发表于 2007-09-20 09:19 |只看该作者
怎么的也要排序吧?那个算法三卷本第二卷开始的计数排序应该是LZ需要的。
dxj_1231 该用户已被删除
9 [报告]
发表于 2007-09-20 12:47 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
10 [报告]
发表于 2007-09-20 13:07 |只看该作者
找出第k大的数——o(n)
查找这个数所在位置——o(n)
总平均时间复杂度——o(n)
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP