# Python | Nested Records Modulo

Sometimes, while working with records, we can have a problem in which we require to perform index wise remainder of tuple elements. This can get complicated with tuple elements to be tuple and inner elements again be tuple. Let’s discuss certain ways in which this problem can be solved.

Method #1 : Using `zip()` + nested generator expression
The combination of above functions can be used to perform the task. In this, we combine the elements across tuples using zip(). The iterations and modulo logic is provided by generator expression.

 `# Python3 code to demonstrate working of ` `# Nested Records Modulo ` `# using zip() + nested generator expression ` ` `  `# initialize tuples ` `test_tup1 ``=` `((``1``, ``3``), (``4``, ``5``), (``2``, ``9``), (``1``, ``10``)) ` `test_tup2 ``=` `((``6``, ``7``), (``3``, ``9``), (``1``, ``1``), (``7``, ``3``)) ` ` `  `# printing original tuples ` `print``(``"The original tuple 1 : "` `+` `str``(test_tup1)) ` `print``(``"The original tuple 2 : "` `+` `str``(test_tup2)) ` ` `  `# Nested Records Modulo ` `# using zip() + nested generator expression ` `res ``=` `tuple``(``tuple``(a ``%` `b ``for` `a, b ``in` `zip``(tup1, tup2))\ ` `    ``for` `tup1, tup2 ``in` `zip``(test_tup1, test_tup2)) ` ` `  `# printing result ` `print``(``"The resultant tuple after modulo : "` `+` `str``(res)) `

Output :

```The original tuple 1 : ((1, 3), (4, 5), (2, 9), (1, 10))
The original tuple 2 : ((6, 7), (3, 9), (1, 1), (7, 3))
The resultant tuple after modulo : ((1, 3), (1, 5), (0, 0), (1, 1))
```

Method #2 : Using `isinstance() + zip()` + loop + list comprehension
The combination of above functions can be used to perform this particular task. In this, we check for the nesting type and perform recursion. This method can give flexibility of more than 1 level nesting.

 `# Python3 code to demonstrate working of ` `# Nested Records Modulo ` `# using isinstance() + zip() + loop + list comprehension ` ` `  `# function to perform task  ` `def` `tup_mod(tup1, tup2): ` `    ``if` `isinstance``(tup1, (``list``, ``tuple``)) ``and` `isinstance``(tup2, (``list``, ``tuple``)): ` `        ``return` `tuple``(tup_mod(x, y) ``for` `x, y ``in` `zip``(tup1, tup2)) ` `    ``return` `tup1 ``%` `tup2 ` ` `  `# initialize tuples ` `test_tup1 ``=` `((``1``, ``3``), (``4``, ``5``), (``2``, ``9``), (``1``, ``10``)) ` `test_tup2 ``=` `((``6``, ``7``), (``3``, ``9``), (``1``, ``1``), (``7``, ``3``)) ` ` `  `# printing original tuples ` `print``(``"The original tuple 1 : "` `+` `str``(test_tup1)) ` `print``(``"The original tuple 2 : "` `+` `str``(test_tup2)) ` ` `  `# Nested Records Modulo ` `# using isinstance() + zip() + loop + list comprehension ` `res ``=` `tuple``(tup_mod(x, y) ``for` `x, y ``in` `zip``(test_tup1, test_tup2)) ` ` `  `# printing result ` `print``(``"The resultant tuple after modulo : "` `+` `str``(res)) `

Output :

```The original tuple 1 : ((1, 3), (4, 5), (2, 9), (1, 10))
The original tuple 2 : ((6, 7), (3, 9), (1, 1), (7, 3))
The resultant tuple after modulo : ((1, 3), (1, 5), (0, 0), (1, 1))
```

My Personal Notes arrow_drop_up Check out this Author's contributed articles.

If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to contribute@geeksforgeeks.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.

Please Improve this article if you find anything incorrect by clicking on the "Improve Article" button below.

Article Tags :

Be the First to upvote.

Please write to us at contribute@geeksforgeeks.org to report any issue with the above content.