September 11, 2024

Python Program to Find Intersection of Two Lists

Finding the intersection of two lists involves identifying elements that are present in both lists. Python provides several ways to achieve this, including using sets and list comprehensions. Below are examples demonstrating different methods to find the intersection of two lists.

1. Using Sets

Using sets is one of the most efficient ways to find the intersection of two lists. Sets in Python are unordered collections of unique elements, which makes them ideal for this operation.

# Define two lists
list1 = [1, 2, 3, 4, 5]
list2 = [4, 5, 6, 7, 8]

# Convert lists to sets and find the intersection
intersection = list(set(list1) & set(list2))

print(intersection)  # Output: [4, 5]
    

2. Using List Comprehension

List comprehension can be used to find the intersection by iterating over one list and checking if each element is present in the other list.

# Define two lists
list1 = [1, 2, 3, 4, 5]
list2 = [4, 5, 6, 7, 8]

# Find intersection using list comprehension
intersection = [value for value in list1 if value in list2]

print(intersection)  # Output: [4, 5]
    

3. Using a Loop

A traditional loop-based approach involves iterating through one list and checking membership in the other list.

# Define two lists
list1 = [1, 2, 3, 4, 5]
list2 = [4, 5, 6, 7, 8]

# Find intersection using a loop
intersection = []
for value in list1:
    if value in list2:
        intersection.append(value)

print(intersection)  # Output: [4, 5]
    

4. Using the filter() Function

The filter() function can also be used in combination with a lambda function to find the intersection.

# Define two lists
list1 = [1, 2, 3, 4, 5]
list2 = [4, 5, 6, 7, 8]

# Find intersection using filter()
intersection = list(filter(lambda x: x in list2, list1))

print(intersection)  # Output: [4, 5]
    

Conclusion

Finding the intersection of two lists can be achieved through various methods in Python, including using sets for efficiency, list comprehensions for readability, loops for a more traditional approach, and the filter() function for functional programming style. Each method has its use cases and advantages, so you can choose based on your specific needs and preferences.