为了账号安全,请及时绑定邮箱和手机立即绑定

如何快速找到数量a的大小处于,数组b中那个键名与键名之间

如何快速找到数量a的大小处于,数组b中那个键名与键名之间

守候你守候我 2018-08-14 11:10:59
变量a = 8 以及已按大小顺序排列好的数组 b = array(1,3,5,7,8.9,9,11.3);假设数组长度未知,变量值未知,数组键值按从小到大已排列好如何快速找到数量a的大小处于,数组b中那个键名与键名之间eg: a=8,处于b[4]与b[5]之间
查看完整描述

1 回答

?
慕容森

TA贡献1853条经验 获得超18个赞

长度未知…………不太可能吧……不就是b.length就完了吗…………
这种查询除了二分还有什么更好的方法吗……

或者自己封装一个class,在数组建立的时候做一个映射,把数据按照大小分组,怎么分组看你的要求,可以大幅提高速度。
比如简单一点,按照整数分组,像这样:

class ClassA extends Array {
    constructor(...args) {        super(...args);        this.hash = [];        for(let i = 0; i < this.length; i++) {            if(!this.hash[Math.floor(this[i])]) this.hash[Math.floor(this[i])] = i;
        }
    }
}

数组还是那个数组不变,只是添加一个hash,里面代表的是整数段的起始下标,比如你要查询8.5这个数,那么只需要查询this.hash[Math.floor(8.5)]this.hash[Math.floor(8.5) + 1],两个下标之间的数据就行了,假如这俩hash里面是空的,那么分别往前、往后找就行,直到找到值为止。要是数据过于稀疏,那么可以给这个hash再做一个hash,记录有效整数段,反正就是空间换时间啦。


查看完整回答
反对 回复 2018-09-19
  • 1 回答
  • 0 关注
  • 548 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信