Hier ist ein Weg, es zu tun vorausgesetzt, Sie haben bereits die Matrix. (Die Frage sagt eine Matrix füllen, schaffen keine Matrix)
import pprint
import random
categories = [0,1,3] #complete pool of numbers
restrictedNumbers = [0, 1] #numbers to only appear once
unrestrictedNumbers = [num for num in categories if num not in restrictedNumbers] #can appear any number of times
matrix = [[0, 0, 0, 0, 0] for l in range(10)] #10 rows, 5 columns matrix of zeros
newMatrix = []
for row in matrix:
tempRow = restrictedNumbers #first add the restricted numbers since they must appear once
while len(tempRow) < len(row): #keep adding numbers from unrestricted till lengths are equal
tempRow.append(random.choice(unrestrictedNumbers))
random.shuffle(tempRow)
newMatrix.append(tempRow[:]) #finally add the shuffled row to newMatrix
pprint.pprint(newMatrix)
Diese den Ausgang gibt: (natürlich wird wegen zufälliger variieren)
[[3, 1, 3, 0, 3],
[3, 3, 0, 1, 3],
[0, 3, 1, 3, 3],
[0, 3, 1, 3, 3],
[3, 3, 0, 3, 1],
[0, 1, 3, 3, 3],
[1, 0, 3, 3, 3],
[1, 3, 0, 3, 3],
[3, 3, 0, 3, 1],
[3, 0, 1, 3, 3]]
Sie können jede Zeile sehen eine einzelne hat 0 und Single ein
Hier ist ein noch kürzerer Weg:
import pprint
import random
categories = [0,1,3] #complete pool of numbers
restrictedNumbers = [0, 1] #numbers to only appear once
unrestrictedNumbers = [num for num in categories if num not in restrictedNumbers] #can appear any number of times
matrix = [[0, 0, 0, 0, 0] for l in range(10)] #10 rows, 5 columns matrix of zeros
newMatrix = []
for row in matrix:
row = restrictedNumbers + [random.choice(unrestrictedNumbers) for _ in range(len(row)-len(restrictedNumbers))]
random.shuffle(row)
newMatrix.append(row)
pprint.pprint(newMatrix)
Und sogar kürzer als die (diese eine Zeile wäre, wenn random.shuffle die Liste zurückgegeben statt anstelle von schlurfenden)
import pprint
import random
categories = [0,1,3] #complete pool of numbers
restrictedNumbers = [0, 1] #numbers to only appear once
unrestrictedNumbers = [num for num in categories if num not in restrictedNumbers] #can appear any number of times
matrix = [[0, 0, 0, 0, 0] for l in range(10)] #10 rows, 5 columns matrix of zeros
def returnShuffled(startList):
random.shuffle(startList)
return startList
newMatrix = [returnShuffled(restrictedNumbers + [random.choice(unrestrictedNumbers) for _ in range(len(row) - len(restrictedNumbers))]) for row in matrix]
pprint.pprint(newMatrix)
Was Sie sagen, 10 x 5 meinst du eine Liste mit 10 Elementen je enthält 5 Elemente oder eine Liste mit 5 Elementen mit je 10 Elementen? – Keatinge
Danke Keatinge, mein A ist ein Array mit 10 Zeilen und 5 Spalten. Danke – user1301295
Was ich möchte ist fast so etwas wie 'np.random.choice ([0, 1, 3], 10 * 5, size = (10,5))', unter der Voraussetzung, dass eine Spalte nur eine haben darf ein 0 Vorkommen und ein und nur ein '1' Vorkommen. – user1301295