我試圖在Ruby中實現Karatsuba乘法沒有返回預期值..方法在Ruby中
# takes two integer x and y and partition them to x=a+b and y=c+d
# example if x = 1234 a=12 and b=34
# recursively compute a*c,a*d,b*c and b*d
def mult (x,y)
if len(x) == 1 && len(y) == 1
return x*y
elsif len(x) > 1 && len(y) > 1
ab = partition(x)
cd = partition(y)
return ab.product(cd).each{ |num| mult(num[0],num[1]) }
end
end
#method for partitioning works fine..
def partition(number)
number.divmod(10**(len(number)/2))
end
#method to find size of integer works fine...
def len(value)
value.to_s.split("").compact.size
end
因此,預期收益爲
p mult(12,34) should be 3,4,6,8
but is [[1, 3], [1, 4], [2, 3], [2, 4]]
代替return x*y
,當我使用print "#{x*y}"
在line no:3
它打印3,4,6,8。我無法理解爲什麼mult
方法返回nil
爲x*y
。
'len(x)'?這聽起來像Python – Ursus
@Ursus它聽起來像自我實現的方法,檢查代碼段的最後3行。 – mudasobwa