开发者社区 问答 正文

获取数组元素的索引比O(n)更快

给定我有一个巨大的数组,以及一个值。我想获取数组中值的索引。还有其他方法,而不是致电Array#index获取吗?问题来自需要保持非常大的数组并调用Array#index大量时间。

经过几次尝试,我发现通过存储具有字段的结构而不是值本身来缓存元素内部的索引(value, index)在性能方面迈出了一大步(获胜20倍)。

我仍然想知道是否有一种更方便的方法来查找en元素的索引而不进行缓存(或者有一种很好的缓存技术可以提高性能)。 问题来源于stack overflow

展开
收起
保持可爱mmm 2020-02-08 10:42:40 480 分享 版权
1 条回答
写回答
取消 提交回答
  • 将数组转换为哈希。然后寻找钥匙。

    array = ['a', 'b', 'c'] hash = Hash[array.map.with_index.to_a] # => {"a"=>0, "b"=>1, "c"=>2} hash['b'] # => 1

    2020-02-08 10:42:57
    赞同 展开评论
问答分类:
问答地址: