![]() |
VOOZH | about |
Sometimes, while working with Python Records lists, we can have problems in which, we need to reform the dictionary taking just values of the binary dictionary. This can have applications in many domains which work with data. Let us discuss certain ways in which this task can be performed.
Method #1 : Using loop + values() + update()
The combination of the above functions can be used to perform this task. In this the values are extracted using values() and updating the new dictionary is done using update().
The original list is : [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
The values dictionary is : {'gfg': 'best', 'for': 'geeks'}
Time Complexity: O(n) where n is the total number of values in the list “test_list”.
Auxiliary Space: O(n) where n is the total number of values in the list “test_list”.
Method #2 : Using zip() + iter()
The combination of the above functions can also be used to perform this task. In this, we perform to convert the list to iterator and pairing of values is done using zip().
The original list is : [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
The values dictionary is : {'gfg': 'best', 'for': 'geeks'}
Time Complexity: O(n) where n is the number of elements in the dictionary. The zip() + iter() is used to perform the task and it takes O(n) time.
Auxiliary Space: O(n) additional space of size n is created where n is the number of elements in the dictionary.
Method #3:Using List comprehension
Algorithm
The original list is : [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
The values dictionary is : {'gfg': 'best', 'for': 'geeks'}Time Complexity: O(N*M)
The loop iterates over each dictionary in the record list once. Therefore, the time complexity of this algorithm is O(N*M), where N is the number of dictionaries in the list and M is the average size of each dictionary.
Auxiliary Space: O(N*M)
The space complexity of this algorithm is O(NM), where N is the number of dictionaries in the list and M is the average size of each dictionary. The res dictionary stores all the values from each dictionary in the list, which can take up NM space. Additionally, other variables and temporary memory used during the execution of the algorithm can also contribute to space complexity.
Method #4: Using for loop+values() method
Approach:
Below is the implementation of the above approach:
The original list is : [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
The values dictionary is : {'gfg': 'best', 'for': 'geeks'}Time Complexity: O(M*N), where M is the length of list of dictionaries and N is the length of each dictionary
Auxiliary Space: O(M*N), where M is the number of keys and N is the number of values
Method #5: Using dictionary comprehension
The original list is : [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
The values dictionary is : {'gfg': 'best', 'for': 'geeks'}Time complexity: O(n), where n is the length of test_list.
Auxiliary space: O(n)
Method #6: Using map() and lambda
The original list is : [{1: 'gfg', 2: 'best'}, {3: 'for', 4: 'geeks'}]
The values dictionary is : {'gfg': 'best', 'for': 'geeks'}Time complexity: O(n), where n is the length of test_list.
Auxiliary space: O(n)