Randomly select elements from list without repetition in Python
Last Updated :
14 Mar, 2023
Python’s built-in module in random module is used to work with random data. The random module provides various methods to select elements randomly from a list, tuple, set, string or a dictionary without any repetition. Below are some approaches which depict a random selection of elements from a list without repetition by: Method 1: Using random.sample() Using the sample() method in the random module. The sample() is an inbuilt method of the random module which takes the sequence and number of selections as arguments and returns a particular length list of items chosen from the sequence i.e. list, tuple, string or set. It is used for random selection from a list of items without any replacement. Example 1:
Python3
import random
List = [ 10 , 20 , 30 , 40 , 50 , 40 ,
30 , 20 , 10 ]
UpdatedList = random.sample( List , 3 )
print (UpdatedList)
|
Output:
[50, 20, 10]
Time Complexity: O(n) where n is the number of elements in the list
Auxiliary Space: O(n), where n is the number of elements in the list
We can also use the sample() method on a sequence of numbers, however, the number of selections should be greater than the size of the sequence. Example 2:
Python3
import random
UpdatedList = random.sample( range ( 1 , 100 ), 5 )
print (UpdatedList)
|
Output:
[51, 50, 97, 22, 6]
Method 2: Using random.choices() Using choices() method in the random library, The choices() method requires two arguments the list and k(number of selections) returns multiple random elements from the list with replacement. However, we need to convert the list into a set in order to avoid repetition of elements. Example 1:
Python3
import random
Set = set ([ 10 , 20 , 30 , 40 , 50 , 40 ,
30 , 20 , 10 ])
UpdatedList = random.choices( list ( Set ), k = 3 )
print (UpdatedList)
|
Output:
[30, 20, 40]
If the choices() method is applied on a sequence of unique numbers than it will return a list of unique random selections only if the k argument (i.e number of selections) should be greater than the size of the list. Example 2:
Python3
import random
List = [i for i in range ( 1 , 100 )]
UpdatedList = random.choices( List , k = 5 )
print (UpdatedList)
|
Output:
[46, 32, 85, 12, 68]
Method 3: Using random.choice() Using the choice() method in random module, the choice() method returns a single random item from a list, tuple, or string. Below is program where choice() method is used on a list of items. Example 1:
Python3
import random
List = [ 10 , 20 , 30 , 40 , 50 , 40 ,
30 , 20 , 10 ]
print (random.choice( List ))
|
Output:
20
Below is a program where choice method is used on sequence of numbers. Example 2:
Python3
import random
print (random.choice( range ( 1 , 100 )))
|
Output:
56
Share your thoughts in the comments
Please Login to comment...