如何对二维数组求和



假设我有二维数组

array= [[10,12,15,17],[16,32,65,47],[45,48,41,23],[36,25,74,98],  [32,19,66,88],...]

我想用红宝石做这件事

arr = [[10+45+32+..,12+48+19,15+41+66+..,17+23+88+..],   [16+36+..,32+25+..,65+74+..,47+98+..]

提前谢谢你。

使用 partition 分隔和收集偶数索引子数组和奇数索引子数组。然后转置每个分区,然后转置每个新形成的子数组的总和。

array = [[10,12,15,17],[16,32,65,47],[45,48,41,23],[36,25,74,98],[32,19,66,88]]
array.partition.with_index { |_,i| i.even? }
               .map { |e| e.transpose.map(&:sum) }
#=> [[87, 79, 122, 128], [52, 57, 139, 145]]

关键方法:Enumerable#partitionInteger#even?Array#transpose。有关详细信息,请参阅 ruby-docs。如果您使用的是 Ruby 版本 <2.4.0,请使用 inject(:+) 而不是 sum ,如下所示:

array.partition.with_index { |_,i| i.even? }
               .map { |e| e.transpose.map { |e| e.inject(:+) } }
#=> [[87, 79, 122, 128], [52, 57, 139, 145]]

最新更新