переводя функцию Python в RI, попробуйте добавить больше данных, перебирая значения, которые я разделил, используя strsplit () в R. Возвращаемое значение исходной функции Python представляет собой список списков, так что это должно быть то же самое в версии R (вектор векторов). Python функция
anbaudauer = 12
planzen_list = [
'tomaten_6',
'karotten_4',
'paprika_7',
'erdbeeren_5',
'koriander_2',
'salat_3',
'zucchini_4',
'gurke_5',
'petersilie_2',
'radieschen_3'
]
def possible_combinations(values, target, with_replacement=True):
def sub_combinations(index, l, r, t, w):
if t == sum(filter(lambda i: isinstance(i, int), l)):
r.append(l)
elif t < sum(filter(lambda i: isinstance(i, int), l)):
return
for u in range(index, len(values)):
sub_combinations(u if w else (u + 1), l + [values[u].split('_')[0], int(values[u].split('_')[1])], r, t, w)
return r
return sub_combinations(0, [], [], target, with_replacement)
raw_combinations = possible_combinations(planzen_list, anbaudauer)
# returns [['tomaten', 6, 'tomaten', 6], ['tomaten', 6, 'karotten', 4, 'koriander', 2], ['tomaten', 6, 'karotten', 4, 'petersilie', 2], ...]
текущее состояние функции R
w <- c(
'tomaten_6',
'karotten_4',
'paprika_7',
'erdbeeren_5',
'koriander_2',
'salat_3',
'zucchini_4',
'gurke_5',
'petersilie_2',
'radieschen_3'
)
n <- length(w)
t <- 12
D <- list()
for (j in 0:n) D[[paste(0, j)]] <- list(c())
for (i in 1:t) D[[paste(i, 0)]] <- list()
for (j in 1:n) {
for (i in 1:t) {
D[[paste(i, j)]] <- do.call(c, lapply(0:floor(i/as.numeric(strsplit(w[j], '_')[[1]][2])), function(r) {
lapply(D[[paste(i-r*as.numeric(strsplit(w[j], '_')[[1]][2]), j-1)]], function(x) c(x, rep(strsplit(w[j], '_')[[1]][1]), r))
}))
}
}
D[[paste(t, n)]]
на as.numeric(strsplit(w[j], '_')[[1]][2])
Я хотел бы добавить название овоща перед номером. По сути, функция R должна возвращать то же, что и функция Python. Преобразовать возвращаемое значение функции R до сих пор было непросто. По сути, я пытался разобрать все и снова соединить. Поскольку я долгое время не использовал R, я уверен, что существует удобный метод для получения тех же данных, которые возвращаются из функции Python.