Je dois créer un tableau de nombres dans une plage, par exemple:Distribution de la gamme dans le tableau
[1..5] en 10 fois = [1,1,2,2,3,3,4, 4,5,5]
[1..5] à 5 fois = [1,2,3,4,5]
[1..5] en 3 fois = [1,3, 5]
def distribute(start_value, end_value, times, is_integer)
array = Array.new(times-1)
min_value = [end_value,start_value].min
max_value = [end_value,start_value].max
if max_value-min_value<times
factor = (max_value-min_value).abs/(array.size).to_f
else
factor = (max_value-min_value).abs/(array.size-1).to_f
end
for i in 0..array.size
v = [ [max_value, factor*(i+1)].min, min_value].max
is_integer ? array[i] = v.round : array[i] = v
end
start_value < end_value ? array : array.reverse
end
distribuer (1, 5, 10, true) => [1, 1, 1, 2, 2, 3, 3, 4, 4, 4 ] #WRONG devrait être [1,1,2,2,3,3,4,4,5,5]
distribuer (5, 1, 5, vrai) => [5, 4, 3, 2, 1] #ok
distribuer (1, 5, 3, true) => [4, 5, 5] #WRONG devrait être [1, 3, 5]
Plutôt que de compliquer l'algorithme pour le cas particulier, vous pouvez court-circuiter la méthode: 'return [] sauf array_size> 0'. Au moins pour moi, il est plus facile de comprendre le code de cette façon. – FMc