Что такое встроенные функции над множеством в Python?

Аватар пользователя Дмитрий Ибрагимов
Дмитрий Ибрагимов
18 января 2023

Множества в Python — это неупорядоченные последовательности элементов, каждый из которых в множестве представлен ровно один раз. Литералы множеств записываются в фигурных скобках, как и литералы словарей т.е. - {}. Однако внутри скобок через запятую перечисляются только элементы множества. Для преобразования списка можно воспользоваться вызовом функции set():

some_list = ['A', 'B', 'B', 'C', 'B', 'C']
some_set = set(some_list)
print(some_set)
# => {'A', 'B', 'C'}
# Вызов функции set() без аргументов создаст пустое множество
a = set()
print(a)
# => {}

Встроенные функции над множеством в Python это функции, которые позволяют выполнять операции с множествами, такие как поиск, объединение, пересечение, вычитание и т.д. Наиболее распространенные встроенные функции над множеством в Python это:

• Функция len() - возвращает длину (количество элементов) множества.

some_set = {6, 7, 8, 45, 18, 23, 30}
print(len(some_set))
# => 7

• Функция max() - возвращает наибольший элемент из множества.

some_set = {6, 7, 8, 45, 18, 23, 30}
print(max(some_set))
# => 45

• Функция min() - возвращает наименьший элемент из множества.

some_set = {6, 7, 8, 45, 18, 23, 30}
print(min(some_set))
# => 6

• Функция sorted() - возвращает отсортированный список из элементов множества.

some_set = {1, 4, 8, 45, 18, 23, 30}
print(some_set)
# {1, 18, 4, 23, 8, 45, 30}
print(sorted(some_set))
# [1, 4, 8, 18, 23, 30, 45]

• Метод a.union(b) - объединяет множества a и b (является аналогом записи a | b) и возвращает новое множество, которое содержит все элементы, содержащиеся хотя бы в одном из оригинальных множеств. По смыслу объединение похоже на операцию "ИЛИ" из булевой логики: элемент будет присутствовать в объединении, если он присутствует в первом исходном множестве ИЛИ во втором.

first_set = {'A', 'B', 'C'}
second_set = {'C', 'D'}
result_set = first_set.union(second_set)
print(result_set)
# => {'B', 'D', 'A', 'C'}

• Метод a.intersection(b) - возвращает пересечение множеств a и b (является аналогом записи a & b), в которое входят элементы, присутствующие в первом из оригинальных множеств "И" во втором.

first_set = {'A', 'B', 'C'}
second_set = {'C', 'D'}
result_set = first_set.intersection(second_set)
print(result_set)
# => {'C'}

• Метод a.difference(b) - возвращает разность множеств a и b (является аналогом записи a - b), в которое входят элементы содержащиеся в первом оригинальном множестве, но не содержатся во втором.

first_set = {'A', 'B', 'C'}
second_set = {'C', 'D'}
result_set = first_set.difference(second_set)
print(result_set)
# => {'A', 'B'}
result_set = second_set.difference(first_set)
print(result_set)
# => {'D'}

• Метод a.symmetric_difference(b) - возвращает симметричную разность множеств a и b (является аналогом записи a ^ b), а именно множество, в которое входят элементы, присутствующие либо в первом, либо во втором оригинальном множестве.

first_set = {'A', 'B', 'C'}
second_set = {'C', 'D'}
result_set = second_set.symmetric_difference(first_set)
print(result_set)
# => {'B', 'D', 'A'}
0 0
Познакомьтесь с основами Python бесплатно