2 回答

TA貢獻1779條經驗 獲得超6個贊
一種方法是使用掩碼用 中的值填充數組的無效條目,ls次數與 的排列相同ls。
但是,通過將這些排列的長度設置為 中無效條目的數量,可以使這更加健壯arr。那樣我們也說明了這個情況len(ls) > (x == None).sum()。
可以使用itertools.permutations以下方法獲得排列:
def fill_combs(x, fill, replace=None):
from itertools import permutations
m = x == replace
for i in permutations(fill, int(m.sum())):
x_ = x.copy()
x_[m] = np.array(i)
yield x_.astype(int)
示例運行:
arr = np.array([
[1, None, 3],
[9, 4, None],
])
ls = [9, 8]
list(fill_with_permut(arr, ls))
輸出:
[array([[1, 9, 3],
[9, 4, 8]]),
array([[1, 8, 3],
[9, 4, 9]])]
或者更大的ls:
ls = [3,5,2]
list(fill_with_permut(arr, ls))
[array([[1, 3, 3],
[9, 4, 5]]),
array([[1, 3, 3],
[9, 4, 2]]),
array([[1, 5, 3],
[9, 4, 3]]),
array([[1, 5, 3],
[9, 4, 2]]),
array([[1, 2, 3],
[9, 4, 3]]),
array([[1, 2, 3],
[9, 4, 5]])]

TA貢獻2080條經驗 獲得超4個贊
def update(arr, items):
count = 0
for i, x in enumerate(arr):
if None in x:
arr[i][x.index(None)] = items[count]
count += 1
return arr
import itertools
ls = [9, 8]
ls_ = list(itertools.permutations(ls))
for items in ls_:
arr = [[1, None, 3],
[9, 4, None]]
print (update(arr,items))
輸出:
[[1, 9, 3], [9, 4, 8]]
[[1, 8, 3], [9, 4, 9]]
例子: ls = [9, 8, 15]
輸出:
[[1, 9, 3], [9, 4, 8]]
[[1, 9, 3], [9, 4, 15]]
[[1, 8, 3], [9, 4, 9]]
[[1, 8, 3], [9, 4, 15]]
[[1, 15, 3], [9, 4, 9]]
[[1, 15, 3], [9, 4, 8]]
添加回答
舉報