Create two-dimensional arrays and access sub-arrays in Ruby

前端 未结 9 968
走了就别回头了
走了就别回头了 2020-11-28 03:26

I wonder if there\'s a possibility to create a two dimensional array and to quickly access any horizontal or vertical sub array in it?

I believe we can access a hor

9条回答
  •  温柔的废话
    2020-11-28 04:04

    There are some problems with 2 dimensional Arrays the way you implement them.

    a= [[1,2],[3,4]]
    a[0][2]= 5 # works
    a[2][0]= 6 # error
    

    Hash as Array

    I prefer to use Hashes for multi dimensional Arrays

    a= Hash.new
    a[[1,2]]= 23
    a[[5,6]]= 42
    

    This has the advantage, that you don't have to manually create columns or rows. Inserting into hashes is almost O(1), so there is no drawback here, as long as your Hash does not become too big.

    You can even set a default value for all not specified elements

    a= Hash.new(0)
    

    So now about how to get subarrays

    (3..5).to_a.product([2]).collect { |index| a[index] }
    [2].product((3..5).to_a).collect { |index| a[index] }
    

    (a..b).to_a runs in O(n). Retrieving an element from an Hash is almost O(1), so the collect runs in almost O(n). There is no way to make it faster than O(n), as copying n elements always is O(n).

    Hashes can have problems when they are getting too big. So I would think twice about implementing a multidimensional Array like this, if I knew my amount of data is getting big.

提交回复
热议问题