如何求和二维数组

时间:2017-01-04 11:57:25

标签: ruby matrix multidimensional-array sketchup

我有一个二维数组= [[12,34,35,21],[10,14,23,17],...]无穷大。

我想在红宝石中这样做;

arr1 = [array[0][0]+array[1][0]+array[n+1][0]...,
array[0][1]+array[1][1]+array[n+1][1]...,
array[0][2]+array[1][2]+array[n+1][2]...,
array[0][3]+array[1][3]+array[n+1][3]...] 

结果(4x4)

arr1 = [[12+10+..],[34+14+..],[35+23..],[21+17+..]]

有什么想法吗?

2 个答案:

答案 0 :(得分:2)

您可以使用Array#transpose,然后对每个数组求和

array = [[12,34,35,21],[10,14,23,17]]

array.transpose.map {|a| a.inject(:+) }
# => [22, 48, 58, 38]

如果您使用的是Ruby 2.4或更高版本,则可以使用Array#sum方法

array.transpose.map(&:sum)
# => [22, 48, 58, 38] 

输出为数组或数组,

array.transpose.map {|a| [a.sum] }
# => [[22], [48], [58], [38]] 

答案 1 :(得分:1)

我刚刚编写了ruby代码

h = Hash.new(0)
arr =  [[12, 34, 35, 21], [10, 14, 23, 17], [1, 2, 3]]  #Any size of nested array
arr.each do |a|
  a.each_with_index do |n,i|
    h[i]+=n
  end
end
h.values.map{|a| [a]}

希望有所帮助