Open In App

Python – Remove Tuples of Length K

Last Updated : 02 May, 2023
Improve
Improve
Like Article
Like
Save
Share
Report

Given list of tuples, remove all the tuples with length K.

Input : test_list = [(4, 5), (4, ), (8, 6, 7), (1, ), (3, 4, 6, 7)], K = 2 
Output : [(4, ), (8, 6, 7), (1, ), (3, 4, 6, 7)] 
Explanation : (4, 5) of len = 2 is removed. 

Input : test_list = [(4, 5), (4, ), (8, 6, 7), (1, ), (3, 4, 6, 7)], K = 3 
Output : [(4, 5), (4, ), (1, ), (3, 4, 6, 7)] 
Explanation : 3 length tuple is removed.

Method #1 : Using list comprehension

This is one of the ways in which this task can be performed. In this, we iterate for all elements in loop and perform the required task of removal of K length elements using conditions.

Python3




# Python3 code to demonstrate working of
# Remove Tuples of Length K
# Using list comprehension
 
# initializing list
test_list = [(4, 5), (4, ), (8, 6, 7), (1, ), (3, 4, 6, 7)]
 
# printing original list
print("The original list : " + str(test_list))
 
# initializing K
K = 1
 
# 1 liner to perform task
# filter just lengths other than K
# len() used to compute length
res = [ele for ele in test_list if len(ele) != K]
 
# printing result
print("Filtered list : " + str(res))


Output

The original list : [(4, 5), (4, ), (8, 6, 7), (1, ), (3, 4, 6, 7)]
Filtered list : [(4, 5), (8, 6, 7), (3, 4, 6, 7)]

Time Complexity: O(n), where n is the number of tuples in the input list.
Auxiliary Space: O(m), where m is the number of tuples in the output list (since we are creating a new list to store the filtered tuples).

Method #2 : Using filter() + lambda + len() 

Yet another way to solve this problem. In this, we perform filtering using filter() and lambda function to extract just non K length elements using len().

Python3




# Python3 code to demonstrate working of
# Remove Tuples of Length K
# Using filter() + lambda + len()
 
# initializing list
test_list = [(4, 5), (4, ), (8, 6, 7), (1, ), (3, 4, 6, 7)]
 
# printing original list
print("The original list : " + str(test_list))
 
# initializing K
K = 1
 
# filter() filters non K length values and returns result
res = list(filter(lambda x : len(x) != K, test_list))
 
# printing result
print("Filtered list : " + str(res))


Output

The original list : [(4, 5), (4, ), (8, 6, 7), (1, ), (3, 4, 6, 7)]
Filtered list : [(4, 5), (8, 6, 7), (3, 4, 6, 7)]

Time complexity: O(n), where n is the length of the input list.
Auxiliary space: O(n), as a new list is created to store the filtered values.

Method #3: Using a loop

Use a for loop to iterate through the list and remove tuples of length K.

Python3




# Python3 code to demonstrate working of
# Remove Tuples of Length K
# Using list comprehension
 
# initializing list
test_list = [(4, 5), (4, ), (8, 6, 7), (1, ), (3, 4, 6, 7)]
 
# printing original list
print("The original list : " + str(test_list))
 
# initializing K
K = 1
 
# using list comprehension to filter out tuples of length K
# len() is used to compute length
res = [ele for ele in test_list if len(ele) != K]
 
# printing result
print("Filtered list : " + str(res))


Output

The original list : [(4, 5), (4,), (8, 6, 7), (1,), (3, 4, 6, 7)]
Filtered list : [(4, 5), (8, 6, 7), (3, 4, 6, 7)]

Time complexity: O(n), where n is the length of the input list.
Auxiliary space: O(n)

METHOD 4:Using map() and lambda function

APPROACH:

The given problem is to remove tuples of a given length k from a list of tuples and return the filtered list.

ALGORITHM:

1.Read the original list and the value of k.
2.Create an empty list to store the filtered tuples.
3.Use the map() function with a lambda function as its first argument to iterate over each tuple in the original list.
4.Use the filter() function with a lambda function as its first argument to filter out the tuples whose length is equal to k.
5.Convert the resulting map object into a list using the list() function and store it in the filtered_list.
6.Print the filtered_list.

Python3




# input
original_list = [(4, 5), (4, ), (8, 6, 7), (1, ), (3, 4, 6, 7)]
k = 1
 
# use map() and a lambda function to filter out tuples of length k
filtered_list = list(map(lambda x: x, filter(lambda x: len(x) != k, original_list)))
 
# output
print(filtered_list)


Output

[(4, 5), (8, 6, 7), (3, 4, 6, 7)]

Time Complexity:
The time complexity of this approach is O(n), where n is the number of tuples in the original list. This is because we are iterating over each tuple in the original list only once.

Space Complexity:
The space complexity of this approach is also O(n), where n is the number of tuples in the original list. This is because we are creating a new list to store the filtered tuples.

METHOD 5 :Using heapq:

Algorithm:

  1. Initialize an empty result list.
  2. Traverse the input list and for each tuple:
    a. Check if the length of the tuple is not equal to K.
    b. If the length is not equal to K, add the tuple to the result list.
  3. Return the result list.

Python3




import heapq
 
# initializing list
test_list = [(4, 5), (4, ), (8, 6, 7), (1, ), (3, 4, 6, 7)]
# printing original list
print("The original list : " + str(test_list))
# initializing K
K = 1
 
# filtering non K length values using heapq
res = list(filter(lambda x: len(x) != K, test_list))
 
# printing result
print("Filtered list : " + str(res))
#This code is contributed by Vinay Pinjala.


Output

The original list : [(4, 5), (4,), (8, 6, 7), (1,), (3, 4, 6, 7)]
Filtered list : [(4, 5), (8, 6, 7), (3, 4, 6, 7)]

Time Complexity: O(N), where N is the number of tuples in the input list. We traverse the list once to filter the tuples.

Auxiliary Space: O(N), where N is the number of tuples in the input list. We create a new list to store the filtered tuples. The size of this list is equal to or less than the size of the input list, depending on the number of tuples that satisfy the condition.



Similar Reads

Python | Remove duplicate tuples from list of tuples
Given a list of tuples, Write a Python program to remove all the duplicated tuples from the given list. Examples: Input : [(1, 2), (5, 7), (3, 6), (1, 2)] Output : [(1, 2), (5, 7), (3, 6)] Input : [('a', 'z'), ('a', 'x'), ('z', 'x'), ('a', 'x'), ('z', 'x')] Output : [('a', 'z'), ('a', 'x'), ('z', 'x')] Method #1 : List comprehension This is a naive
5 min read
Python | Remove tuples from list of tuples if greater than n
Given a list of a tuple, the task is to remove all the tuples from list, if it's greater than n (say 100). Let's discuss a few methods for the same. Method #1: Using lambda STEPS: Initialize a list of tuples: ini_tuple = [('b', 100), ('c', 200), ('c', 45), ('d', 876), ('e', 75)]Print the initial list: print("intial_list", str(ini_tuple))Define the
6 min read
Python | Remove tuples having duplicate first value from given list of tuples
Given a list of tuples, the task is to remove all tuples having duplicate first values from the given list of tuples. Examples: Input: [(12.121, 'Tuple1'), (12.121, 'Tuple2'), (12.121, 'Tuple3'), (923232.2323, 'Tuple4')] Output: [(12.121, 'Tuple1'), (923232.2323, 'Tuple4')]Input: [('Tuple1', 121), ('Tuple2', 125), ('Tuple1', 135), ('Tuple4', 478)]
7 min read
Python | Find the tuples containing the given element from a list of tuples
Given a list of tuples, the task is to find all those tuples containing the given element, say n. Examples: Input: n = 11, list = [(11, 22), (33, 55), (55, 77), (11, 44)] Output: [(11, 22), (11, 44)] Input: n = 3, list = [(14, 3),(23, 41),(33, 62),(1, 3),(3, 3)] Output: [(14, 3), (1, 3), (3, 3)] There are multiple ways we can find the tuples contai
6 min read
Python | Count tuples occurrence in list of tuples
Many a time while developing web and desktop products in Python, we use nested lists and have several queries about how to find the count of unique tuples. Let us see how to get the count of unique tuples in the given list of tuples. Below are some ways to achieve the above task. Method #1: Using Iteration C/C++ Code # Python code to count unique #
5 min read
Python | Combining tuples in list of tuples
Sometimes, we might have to perform certain problems related to tuples in which we need to segregate the tuple elements to combine with each element of complex tuple element( such as list ). This can have application in situations we need to combine values to form a whole. Let's discuss certain ways in which this can be performed. Method #1: Using
7 min read
Python | Convert string tuples to list tuples
Sometimes, while working with Python we can have a problem in which we have a list of records in form of tuples in stringified form and we desire to convert them to a list of tuples. This kind of problem can have its occurrence in the data science domain. Let's discuss certain ways in which this task can be performed. Method 1 (Using eval() + list
4 min read
Python | How to Concatenate tuples to nested tuples
Sometimes, while working with tuples, we can have a problem in which we need to convert individual records into a nested collection yet remaining as separate element. Usual addition of tuples, generally adds the contents and hence flattens the resultant container, this is usually undesired. Let's discuss certain ways in which this problem is solved
6 min read
Python - Filter all uppercase characters Tuples from given list of tuples
Given a Tuple list, filter tuples that contain all uppercase characters. Input : test_list = [("GFG", "IS", "BEST"), ("GFg", "AVERAGE"), ("GfG", ), ("Gfg", "CS")] Output : [('GFG', 'IS', 'BEST')] Explanation : Only 1 tuple has all uppercase Strings. Input : test_list = [("GFG", "iS", "BEST"), ("GFg", "AVERAGE"), ("GfG", ), ("Gfg", "CS")] Output : [
8 min read
Python program to find Tuples with positive elements in List of tuples
Given a list of tuples. The task is to get all the tuples that have all positive elements. Examples: Input : test_list = [(4, 5, 9), (-3, 2, 3), (-3, 5, 6), (4, -6)] Output : [(4, 5, 9)] Explanation : Extracted tuples with all positive elements. Input : test_list = [(-4, 5, 9), (-3, 2, 3), (-3, 5, 6), (4, -6)] Output : [] Explanation : No tuple wit
10 min read
three90RightbarBannerImg