VOOZH about

URL: https://www.geeksforgeeks.org/python/python-column-mapped-tuples-to-dictionary-items/

⇱ Python - Column Mapped Tuples to dictionary items - GeeksforGeeks


  • Courses
  • Tutorials
  • Interview Prep

Python - Column Mapped Tuples to dictionary items

Last Updated : 23 Apr, 2023

Given Tuple Matrix of length 2, map each column's element value with next column and construct dictionary keys.

Input : test_list = [[(1, 4), (6, 3), (4, 7)], [(7, 3), (10, 14), (11, 22)]] Output : {1: 7, 4: 3, 6: 10, 3: 14, 4: 11, 7: 22} Explanation : 1 -> 7, 4 -> 3.., as in same column and indices. Input : test_list = [[(1, 4), (6, 3)], [(7, 3), (10, 14)]] Output : {1: 7, 4: 3, 6: 10, 3: 14} Explanation : Self explanatory column wise pairing.

Method #1 : Using loop 

This is one of the ways in which this task can be performed. In this, we iterate for all the elements with their next column elements and construct dictionary key-value pair.


Output

The original list : [[(5, 6), (7, 4), (1, 2)], [(7, 3), (10, 14), (11, 22)]] The constructed dictionary : {5: 7, 6: 3, 7: 10, 4: 14, 1: 11, 2: 22}

Time Complexity: O(n*n), where n is the elements of dictionary
Auxiliary Space: O(n), where n is the size of dictionary

Method #2 : Using dictionary comprehension + zip()

The combination of above functions provides one-liner to solve this problem. In this, we perform the task of zipping all the columns using zip() and dictionary comprehension is used to key-value pairs.


Output

The original list : [[(5, 6), (7, 4), (1, 2)], [(7, 3), (10, 14), (11, 22)]] The constructed dictionary : {5: 7, 6: 3, 7: 10, 4: 14, 1: 11, 2: 22}

Time Complexity: O(n*n) where n is the number of elements in the list “test_list”. 
Auxiliary Space: O(n) where n is the number of elements in the list “test_list”. 

Method 3: Using itertools and reduce

  1. Import the itertools and functools libraries.
  2. Use the itertools.zip_longest() function to zip together the tuples in the test_list.
  3. Use the functools.reduce() function to iterate over the zipped tuples and construct the dictionary.
  4. For each tuple, use a dictionary comprehension to construct a dictionary where the first element of the tuple is the key and the second element is the value.
  5. Merge the dictionaries using the dict.update() method.

Output
The constructed dictionary : {5: 7, 6: 3, 7: 10, 4: 14, 1: 11, 2: 22}

Time complexity: O(nm), where n is the length of the test_list and m is the maximum length of the tuples in the list.
Auxiliary space: O(nm), where n is the length of the test_list and m is the maximum length of the tuples in the list.

Comment