以前没见过这个,但我想知道如何在 Ruby 中找到二维数组的两条对角线之和。假设您有一个简单的数组,包含 3 行和 3 列。
array = [1,2,3,4,5,6,7,8,9]
我可以通过使用将它分成三个一组
array.each_slice(3).to_a
现在是
[1,2,3], [4,5,6], [7,8,9]
[1,2,3]
[4,5,6]
[7,8,9]
在这种情况下,对角线是
1 + 5 + 9 = 15
3 + 5 + 7 = 15
所以总和为 15 + 15 = 30
我想我可以做类似的事情
diagonal_sum = 0
for i in 0..2
for j in 0..2
diagonal_sum += array[i][j]
end
end
最佳答案
这是我的尝试:
array = [1,2,3,4,5,6,7,8,9]
sliced = array.each_slice(3).to_a
# As sliced size is 3, I took 2, i.e. 3 - 1
(0..2).map { |i| sliced[i][i] } #=> [1, 5, 9]
(0..2).map { |i| sliced[i][-i-1] } # => [3, 5, 7]
(0..2).map { |i| sliced[i][i] }.reduce :+
# => 15
(0..2).map { |i| sliced[i][-i-1] }.reduce :+
# => 15
根据上面的观察,您似乎可以在一次迭代中解决:
left_diagonal, right_diagoal = (0..2).each_with_object([[], []]) do |i, a|
a[0] << sliced[i][i]
a[1] << sliced[i][-i-1]
end
left_diagonal.reduce(:+) # => 15
right_diagonal.reduce(:+) # => 15
添加了OOP代码风格:
class SquareMatrix
attr_reader :array, :order
def initialize array, n
@array = array.each_slice(n).to_a
@order = n
end
def collect_both_diagonal_elements
(0...order).collect_concat { |i| [ array[i][i], array[i][-i-1] ] }
end
def collect_left_diagonal_elements
(0...order).collect { |i| array[i][i] }
end
def collect_right_diagonal_elements
(0...order).collect { |i| array[i][-i-1] }
end
def sum_of_diagonal_elements type
case type
when :all then collect_both_diagonal_elements.reduce(0, :+)
when :right then collect_right_diagonal_elements.reduce(0, :+)
when :left then collect_left_diagonal_elements.reduce(0, :+)
end
end
end
array = [1,2,3,4,5,6,7,8,9]
sqm = SquareMatrix.new array, 3
sqm.collect_both_diagonal_elements # => [1, 3, 5, 5, 9, 7]
sqm.sum_of_diagonal_elements :all # => 30
sqm.collect_left_diagonal_elements # => [1, 5, 9]
sqm.sum_of_diagonal_elements :left # => 15
sqm.collect_right_diagonal_elements # => [3, 5, 7]
sqm.sum_of_diagonal_elements :right # => 15
关于Ruby Arrays - 求对角线的总和,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28917105/
以前没见过这个,但我想知道如何在Ruby中找到二维数组的两条对角线之和。假设您有一个简单的数组,包含3行和3列。array=[1,2,3,4,5,6,7,8,9]我可以通过使用将它分成三个一组array.each_slice(3).to_a现在是[1,2,3],[4,5,6],[7,8,9][1,2,3][4,5,6][7,8,9]在这种情况下,对角线是1+5+9=153+5+7=15所以总和为15+15=30我想我可以做类似的事情diagonal_sum=0foriin0..2forjin0..2diagonal_sum+=array[i][j]endend
我有一个字符串数组,我需要从中提取第一个单词,将它们转换为整数并获得它们的总和。示例:["5Apple","5Orange","15Grapes"]预期输出=>25我的尝试:["5","5","15"].map(&:to_i).sum 最佳答案 我从你的问题中找到了答案。["5Apple","5Orange","15Grapes"].map(&:to_i).sum在数组中,如果存在任何整数可转换值,那么它将自动转换为整数。 关于arrays-字符串数组中字符串第一部分的总和,我们在Sta
我正在尝试使用我的2Druby数组解决一些问题,当我进行数组切片时,我的LOC减少了很多。例如,require"test/unit"classLibraryTest我想知道是否有办法得到对角切片?假设我想从[0,0]开始并想要一个3的对角线切片。然后我会从[0,0]、[1,1]、[2,2]获取元素,我会得到一个数组[1,4,7]上面的例子。是否有任何神奇的单行ruby代码可以实现这一目标?3.次做{一些神奇的东西?} 最佳答案 puts(0..2).collect{|i|array[i][i]}
在Ruby中,我想获取一个数字数组,选择2个不同的数字,将这2个数字加在一起,然后查看那里的天气等于变量x.y'davariablex。这是我使用的代码defarrayIsEqual?(numArray,x)returntrueifnumArray.sample+numArray.sample==xreturnfalseifnumArray.empty?||numArray.count==1end例如numArray=[4,2,7,5]x=11arrayIsEqual(numArray,n)应该返回true,因为4+7=n(11)我如何让它工作?我不希望它是2个随机数,只是加起来为n的
518.零钱兑换II1.代码classSolution{public:intchange(intamount,vector&coins){vectorf(amount+1,0);f[0]=1;for(inti=0;i2.动规五部曲1.确定dp数组和其下标含义由题目说可知求选择钱票得到总和为target的方案数,dp[j]相当于选择物品体积相加为i的方案数2.递推公式每次加入物品,都有可能到达体积j,所以在每次加上这个物品到达j时加上这个方案数f[j]+=f[j-coins[i]];3.初始化因为在for循环和dp公式中没有确切的值,肯定需要初始化,初始化第一个就可以保证后面的推导出来了,f[0
我在我的Rails应用程序(4.1.2)中使用payments.sum(&:price)。自从我从Ruby1.9.3更新到2.1.2后,出现了以下错误:wrongnumberofarguments(1for2..3)这些变体有效:payments.map(&:price).sumpayments.to_a.sum(&:price)我必须重写我的代码还是我遗漏了什么?谢谢! 最佳答案 来自documentation:sum(*args)Calculatesthesumofvaluesonagivencolumn.Thevalueisr
假设我们有一个包含整数的项目列表:USA:3peopleAustralia:2peopleGermany:2people如果我们计算每个值占整个列表总和的百分比,我们得到:USA:3/(3+2+2)*100=42.857...%Australia:2/(3+2+2)*100=28.571...%Germany:2/(3+2+2)*100=28.571...%如果我们四舍五入,我们得到:USA:43%Australia:29%Germany:29%总和43+29+29=101不是100,这对软件用户来说有点奇怪。你会如何解决这个问题? 最佳答案
这个问题在这里已经有了答案:Groupobjectsbymultiplepropertiesinarraythensumuptheirvalues(16个答案)关闭3年前。如果CategoryId相同,下面的代码会添加金额,并根据CategoryId创建一个新的行项目。self.OriginalLineItems=[{CategoryId:'Cat1',Amount:15,Type:'TypeA'},{CategoryId:'Cat1',Amount:30,Type:'TypeA'},{CategoryId:'Cat1',Amount:20,Type:'TypeB'},{Categor
p8有些的结论需要直接记住目录矩阵转置 主对角线和次对角线下三角 和上三角(一般是让求和)下三角 上三角杨辉三角矩阵转置 不是方阵需要用到第二个二维数组 b[i][j]=a[i][j]是方阵 方法1借助第二个二维数组,同上方法2 下三角换即可(是方阵的话一般题目都是让你用第二个方法)voidmain(){ inti,j,temp,arr[4][4]={{1,2,3,4},{5,6,7,8},{9,10,11,12},{13,14,15,16}}; for(i=0;i主对角线和次对角线主对角线: i==j次对角线: i+j==数组维度-1voidmain(){ inti,j,arr[3]
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visitthehelpcenter.关闭9年前。我想像这样对数组求和112=4221=5331=7===664我想在html中使用java脚本打印这样的数组总和。