Mam następującą funkcję Pythona rekursywnie Znajdź wszystkie rozbicie zbioru:Przełożenie na znalezienie wszystkich rozbicie zbioru z Python Ruby
def partitions(set_):
if not set_:
yield []
return
for i in xrange(2**len(set_)/2):
parts = [set(), set()]
for item in set_:
parts[i&1].add(item)
i >>= 1
for b in partitions(parts[1]):
yield [parts[0]]+b
for p in partitions(["a", "b", "c", "d"]):
print(p)
Czy ktoś może mi pomóc przetłumaczyć ten w Ruby? Oto, co mam do tej pory:
def partitions(set)
if not set
yield []
return
end
(0...2**set.size/2).each { |i|
parts = [Set.new, Set.new]
set.each { |item|
parts[i&1] << item
i >>= 1
}
partitions(parts[1]).each { |b|
yield [parts[0]] << b
}
}
end
p partitions([1, 2, 3, 4].to_set)
Otrzymuję błąd "LocalJumpError: no block given". Sądzę, że dzieje się tak dlatego, że funkcje wydajności działają inaczej w Pythonie i Ruby.
Gdzie znalazłaś partycje funkcji Python? Aby kontekstualizować rzeczy i uczyć się, chciałbym przeczytać wpis w blogu lub rozdział, w którym go znalazłeś. Dzięki. –