免费注册 查看新帖 |

Chinaunix

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

[算法] 有一个集合,如何能很快的定位大于给定数的最小元素? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-05-16 12:54 |只看该作者 |倒序浏览
比如,一组数103,5,8,26,12,99, 怎么存储,能快速定位到其中大于x的最小的数,并返回其地址?
比如:
x=1, 返回5的地址
x=6, 返回8的地址
x=100, 返回103的地址
x =200, 返回null
这组数是会变动的,给定的x也是随机的。
用什么结构存储,能够不每次都遍历呢?(修改或者查找都算在内)

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
2 [报告]
发表于 2013-05-16 13:01 |只看该作者
范围有限的话就用位图类似的吧

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
3 [报告]
发表于 2013-05-16 13:07 |只看该作者
比如:
#define MAX 1000

int a[MAX] = {0};

103,5,8,26,12,99,
初始化后
a[5-1] = 1;
a[8-1] = 1;
a[12-1] = 1;
...
a[103-1] = 1;

根据x找
if(a[x])
    return x-1;
while(!a[x+1]) x++;
return x;

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
4 [报告]
发表于 2013-05-16 13:18 |只看该作者
用树,C++的话可以直接用set

论坛徽章:
0
5 [报告]
发表于 2013-05-16 13:46 |只看该作者
本帖最后由 Frahm 于 2013-05-16 13:48 编辑

回复 3# cokeboL


    其实那组数是我虚构的,真实的情况是随机的,个数也是会变的

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
6 [报告]
发表于 2013-05-16 16:30 |只看该作者
map, lower_bound。

论坛徽章:
0
7 [报告]
发表于 2013-05-17 09:10 |只看该作者
用二叉树不行么 无论你随机 插入的时候就排序好了  

论坛徽章:
3
2015年迎新春徽章
日期:2015-03-04 09:56:11数据库技术版块每日发帖之星
日期:2016-08-03 06:20:00数据库技术版块每日发帖之星
日期:2016-08-04 06:20:00
8 [报告]
发表于 2013-05-17 10:36 |只看该作者
如果不是排序的结构,复杂度O(n)
排序的结构,通用复杂度O(logn)
桶这样的非通用算法,O(1)
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP