Class SparseVector
attr_reader :vector
def initialize(h = {})
@vector = Hash.new(0)
@vector = @vector.merge!(h)
end
def [](i)
@vector[i]
end
def to_s
@vector.to_s
end
end
class SparseMatrix
attr_reader :matrix
def initialize(h = {})
@matrix = Hash.new({})
for k in h.keys do
@matrix[k] = if h[k].is_a? SparseVector
h[k]
else
@matrix[k] = SparseVector.new(h[k])
end
end
end
def [](i)
@matrix[i]
end
def col(j)
c = {}
for r in @matrix.keys do
c[r] = @matrix[r].vector[j] if
@matrix[r].vector.keys.include? j
end
SparseVector.new c
end
end
##Llamo a la Clase SparseMatrix pasandole un vector para el Hash###
hsh = SparseMatrix.new 1 => {1 => 33, 2 => 44, 3 => 55}, 2 => {1 => 66,
3 => 77}
puts hsh[1][3]
puts hsh.col(2)
Este es el código que tengo,necesito saber si puedo acceder a los
índices del hash de alguna manera recorriendolo mediante un bucle.
He probado mediante un each do y no lo he conseguido hacer.
Necesito realizar esto para realizar operaciones entre matrices densas y
matrices dispersas.