Don’t miss the chance of Java programs examples with output pdf free download as it is very essential for all beginners to experienced programmers for cracking the interviews.
Lists in Python:
Lists are one of Python’s most commonly used built-in data structures. You can make a list by putting all of the elements inside square brackets[ ] and separating them with commas. Lists can include any type of object, making them extremely useful and adaptable.
Given a list/array, the task is to find the minimum index of the repeating element in the given list in Python.
Examples:
Example1:
Input:
given list = [8, 12, 38, 7, 1, 9, 19, 11, 45, 62, 57, 18, 12, 32, 45, 7, 1]
Output:
The minimum index of the repeating element of the given list [8, 12, 38, 7, 1, 9, 19, 11, 45, 62, 57, 18, 12, 32, 45, 7, 1] : 1
Example2:
Input:
given list =[7, 86, 23, 96, 11, 23, 45, 78, 96, 23, 79, 123, 456, 789]
Output:
The minimum index of the repeating element of the given list [7, 86, 23, 96, 11, 23, 45, 78, 96, 23, 79, 123, 456, 789] : 2
Program to Find the Minimum Index of a Repeating Element in an Array/List in Python
Below is the full approach for finding the minimum index of the repeating element in the given list in Python
- Using Hashing with Counter() function(Static Input)
- Using Hashing with Counter() function(User Input)
1)Using Hashing with Counter() function(Static Input)
Counter() function:
The Counter class is a subset of the object data-set offered by Python3’s collections module. The Collections module provides the user with specialized container datatypes, acting as an alternative to Python’s general-purpose built-ins such as dictionaries, lists, and tuples.
The counter is a subclass that counts hashable objects. When called, it constructs an iterable hash table implicitly.
Approach:
- Import the Counter function from the collections module.
- Give the list as static input and store it in a variable.
- Calculate the frequency of all the elements of the given list using the Counter() function and store it in a variable.
- Traverse the given list using For loop.
- Check if the element has a frequency greater than 1 using the if statement.
- If it has a frequency greater than 1, then print the iterator value of the loop(which is the minimum index of the repeating element)
- Break the loop using a break statement
- The Exit of the Program.
Below is the implementation:
# Import the Counter function from the collections module. from collections import Counter # Give the list as static input and store it in a variable. given_list = [8, 12, 38, 7, 1, 9, 19, 11, 45, 62, 57, 18, 12, 32, 45, 7, 1] # Calculate the frequency of all the elements of the given list # using the Counter() function and store it in a variable. elemeFreq = Counter(given_list) # Traverse the given list using For loop. for indeval in range(len(given_list)): # Check if the element has a frequency greater than 1 using the if statement. if(elemeFreq[given_list[indeval]] > 1): # If it has a frequency greater than 1, then print the iterator value of the loop # (which is the minimum index of the repeating element) print('The minimum index of the repeating element of the given list', given_list, ':\n', indeval) # Break the loop using the break statement break
Output:
The minimum index of the repeating element of the given list [8, 12, 38, 7, 1, 9, 19, 11, 45, 62, 57, 18, 12, 32, 45, 7, 1] : 1
Since we iterate only once the Time Complexity of the above approach is O(n).
2)Using Hashing with Counter() function(User Input)
Approach:
- Import the Counter function from the collections module.
- Give the list as user input using split(),int,map() and list() functions.
- Store it in a variable.
- Calculate the frequency of all the elements of the given list using the Counter() function and store it in a variable.
- Traverse the given list using For loop.
- Check if the element has a frequency greater than 1 using the if statement.
- If it has a frequency greater than 1, then print the iterator value of the loop(which is the minimum index of the repeating element)
- Break the loop using a break statement
- The Exit of the Program.
Below is the implementation:
# Import the Counter function from the collections module. from collections import Counter # Give the list as user input using split(),int,map() and list() functions. # Store it in a variable. given_list = list( map(int, input('Enter some random list elements separated by spaces = ').split())) # Calculate the frequency of all the elements of the given list # using the Counter() function and store it in a variable. elemeFreq = Counter(given_list) # Traverse the given list using For loop. for indeval in range(len(given_list)): # Check if the element has a frequency greater than 1 using the if statement. if(elemeFreq[given_list[indeval]] > 1): # If it has a frequency greater than 1, then print the iterator value of the loop # (which is the minimum index of the repeating element) print('The minimum index of the repeating element of the given list', given_list, ':\n', indeval) # Break the loop using break statement break
Output:
Enter some random list elements separated by spaces = 7 86 23 96 11 23 45 78 96 23 79 123 456 789 The minimum index of the repeating element of the given list [7, 86, 23, 96, 11, 23, 45, 78, 96, 23, 79, 123, 456, 789] : 2
Since we iterate only once the Time Complexity of the above approach is O(n).
Related Programs:
- Python Program to Find the Missing Number in an array/list
- Python Program to Find a Pair with the Given Sum in an Array
- Python Program to Sort a List of Tuples in Increasing Order by the Last Element in Each Tuple
- Python Program to Find the Sum of Elements in a List Recursively
- Python Program to Find all Numbers in a Range which are Perfect Squares and Sum of all Digits in the Number is Less than 10
- Python Program to Remove the Characters of Odd Index Values in a String
- Python Program to Find the Factorial of a Number