Let's say I have
mychoice = random.choice(['this is random response 1','this is random response 2',
'this is random response 3', 'and 4', 'and so on'])
How can I avoid having the same choice being repeated more than once in a row? Or how can I can I set a condition to make a particular choice only appear after a certain number of other choices have been chosen? Or is there a module better suited to my needs in this regard?
Example implementation ensuring a minimum distance between two occurrences of the same item:
the simplest solution would probably be to construct a
usedQueue
of lengthk
(where k is the number of selections before a choice is allowed to repeat.) When you select a choice, remove it from your original list and place it inusedQueue
. Then, ifusedQueue.length > k
, pop one back onto your array.As already stated, this significantly reduces the randomness of your algorithm. That said, it does have practical uses (take a look at iTunes.)
This routine selects and prints random choices from mylist without replacement, until all choices have been exhausted.