If you were going to add a contains
function, it might look like this:
#include <algorithm>
#include <iterator>
template<class TInputIterator, class T> inline
bool contains(TInputIterator first, TInputIterator last, const T& value)
{
return std::find(first, last, value) != last;
}
template<class TContainer, class T> inline
bool contains(const TContainer& container, const T& value)
{
// This works with more containers but requires std::begin and std::end
// from C++0x, which you can get either:
// 1. By using a C++0x compiler or
// 2. Including the utility functions below.
return contains(std::begin(container), std::end(container), value);
// This works pre-C++0x (and without the utility functions below, but doesn't
// work for fixed-length arrays.
//return contains(container.begin(), container.end(), value);
}
template<class T> inline
bool contains(const std::set<T>& container, const T& value)
{
return container.find(value) != container.end();
}
This works with std::set
, other STL containers, and even fixed-length arrays:
void test()
{
std::set<int> set;
set.insert(1);
set.insert(4);
assert(!contains(set, 3));
int set2[] = { 1, 2, 3 };
assert(contains(set2, 3));
}
Edit:
As pointed out in the comments, I unintentionally used a function new to C++0x (std::begin
and std::end
). Here is the near-trivial implementation from VS2010:
namespace std {
template<class _Container> inline
typename _Container::iterator begin(_Container& _Cont)
{ // get beginning of sequence
return (_Cont.begin());
}
template<class _Container> inline
typename _Container::const_iterator begin(const _Container& _Cont)
{ // get beginning of sequence
return (_Cont.begin());
}
template<class _Container> inline
typename _Container::iterator end(_Container& _Cont)
{ // get end of sequence
return (_Cont.end());
}
template<class _Container> inline
typename _Container::const_iterator end(const _Container& _Cont)
{ // get end of sequence
return (_Cont.end());
}
template<class _Ty,
size_t _Size> inline
_Ty *begin(_Ty (&_Array)[_Size])
{ // get beginning of array
return (&_Array[0]);
}
template<class _Ty,
size_t _Size> inline
_Ty *end(_Ty (&_Array)[_Size])
{ // get end of array
return (&_Array[0] + _Size);
}
}
Improve Article
Save Article
Like Article
Improve Article
Save Article
Like Article
The set::find is a built-in function in C++ STL which returns an iterator to the element which is searched in the set container. If the element is not found, then the iterator points to the position just after the last element in the set.
Syntax:
set_name.find(element)
Parameters: The function accepts one mandatory parameter element which specifies the element to be searched in the set container.
Return Value: The function returns an iterator which points to the element which is searched in the set container. If the element is not found, then the iterator points to the position just after the last element in the set.
Below program illustrates the above function.
CPP
#include <bits/stdc++.h>
using
namespace
std;
int
main()
{
set<
int
> s;
s.insert(1);
s.insert(4);
s.insert(2);
s.insert(5);
s.insert(3);
auto
pos = s.find(3);
cout <<
"The set elements after 3 are: "
;
for
(
auto
it = pos; it != s.end(); it++)
cout << *it <<
" "
;
return
0;
}
Output
The set elements after 3 are: 3 4 5
Time Complexity: The time complexity of set_name.find( key ) is O( log N ). As the elements are stored in a sorted manner by default.
Special Case: When the element being searched for is not present in the set, an iterator pointing to the end of the set is returned.
Below program illustrates this:
C++
#include <bits/stdc++.h>
using
namespace
std;
int
main()
{
set<
int
> s;
s.insert(1);
s.insert(4);
s.insert(2);
s.insert(5);
s.insert(3);
auto
pos = s.find(6);
if
(pos != s.end())
cout <<
"Element found at position : "
<< distance(s.begin(), pos) << endl;
else
cout <<
"Element not present in set"
;
return
0;
}
Output
Element not present in set
Time complexity: O(log n) // n is the number of elements in the set
Auxiliary space: O(n)
Last Updated :
16 Feb, 2023
Like Article
Save Article
In this article we will discuss how to check if a given element exists in set or not.
Suppose we have a set of strings i.e.
Advertisements
// Set of strings std::set<std::string> setOfStrs = { "the", "is", "of" , "from" , "at" , "hello" , "the" };
Now we wnat to check if any given string exists in the set or not. Let’s do this using two different techniques i.e.
Search for an element in Set using set::find()
std::set provides a member function to find the existance of a given element in set i.e.
Frequently Asked:
- How to Access Element by index in a Set | C++
- Set vs Map : How to choose a right associative container ?
- Different ways to Erase / Delete an element from a Set in C++
- C++: Convert Set to Vector
iterator find (const value_type& val);
It accepts the element as argument and search for that in the set. If the element is found in set then it returns the iterator pointing to that element else it returns the iterator pointing to the end of set.
Let’s use set::find() function to check if “at” exists in above set or not i.e.
// search for the iterator of given string in set std::set<std::string>::iterator it = setOfStrs.find("at"); // Check if iterator it is valid if (it != setOfStrs.end()) { std::cout << "'at' found in set" << std::endl; }
We can not modify the element pointed by this iterator because this element is used for indexing inside the set, changing it will make the indexing wrong. Therefore we can access the element through iterator but cannot modify it.
Search for an element in Set using set::count()
std::set provides a member function to find the occurrence count of a given element in set i.e.
size_type count (const value_type& val) const;
It accepts the element as argument and search for its occurrence count in the set. As std::set can contain only unique elements, so occurrence count of the given element can be only 0 or 1 i.e,
If found then 1 else 0.
Let’s use set::count() function to check if “hello” exists in above set or not i.e.
// Fetch the occurrence count of given string in set if (setOfStrs.count("hello") != 0) { std::cout << "'hello' found in set" << std::endl; }
Checkout the complete example as follows,
#include <iostream> #include <set> #include <string> #include <algorithm> #include <iterator> int main() { // Set of strings std::set<std::string> setOfStrs = { "the", "is", "of" , "from" , "at" , "hello" , "the" }; // search for the iterator of given string in set std::set<std::string>::iterator it = setOfStrs.find("at"); // Check if iterator it is valid if (it != setOfStrs.end()) { std::cout << "'at' found in set" << std::endl; } // Modification is not allowed //*it = "AND"; // search for the iterator of given string in set it = setOfStrs.find("text"); // Check if iterator it is valid if (it != setOfStrs.end()) std::cout << "'text' found in set" << std::endl; else std::cout << "'text' not found in set" << std::endl; // Fetch the occurrence count of given string in set if (setOfStrs.count("hello") != 0) { std::cout << "'hello' found in set" << std::endl; } return 0; }
Output:
'at' found in set 'text' not found in set 'hello' found in set
Both set::find() and set:: count() helps to check the existence of an element in set. But why 2 different method for same thing ?
Complexity wise both find() and count() are same. Main difference is that set::find() returns the iterator of the given element. Iterator is useful if we have user define objects in set, instead of primitive data types.
As set::find() returns the iterator, We can perform operations on the object pointed by iterator, also we can modify the mutable content of that object
Suppose we have a struct Student i.e.
// Student with ID and name // Name is mutable, so can be modified by const object struct Student { int mId; mutable std::string mName; Student(int id, std::string name) : mId(id), mName(name) { } };
A Functor / Comparator, to compare Student objects using ID i.e.
// Student comparator / Functor // Compare objects with ID only struct StudentComp { bool operator()(const Student& lhs, const Student& rhs) const { return lhs.mId < rhs.mId; } };
Let’s Create a set of Student objects i.e.
// Set of Student class objects std::set<Student, StudentComp> setOfStudents = { Student(1, "Shaun"), Student(2, "Riti"), Student(3, "Aadi"), Student(4,"Vicky"), Student(5, "Renu") };
Find a Student object with id 3 using set::find() and modify its name, because mName is mutable and can be modifies eve with const objects i.e.
// Find a student with id 3 std::set<Student, StudentComp>::iterator it = setOfStudents.find( Student(3, "")); // Check if Iterator is valid if (it != setOfStudents.end()) { // Modify the mutuable content which is not // used in comparision or indexing it->mName = "Aarav"; std::cout << it->mId << " :: " << it->mName << std::endl; }
Now search for an element with count() i.e.
// Check if a student with ID 3 exists in set // Not possible to fetch the iterator with count(), // It returns the count only if (setOfStudents.count(Student(3, "")) != 0) { std::cout << it->mId << " Exist in Set" << std::endl; }
We will not get any iterator with set::count(), so its not possible to perform any operation or modify content with count().
Complete example is as follows,
#include <iostream> #include <set> #include <string> #include <algorithm> #include <iterator> // Student with ID and name // Name is mutable, so can be modified by const object struct Student { int mId; mutable std::string mName; Student(int id, std::string name) : mId(id), mName(name) { } }; // Student comparator / Functor // Compare objects with ID only struct StudentComp { bool operator()(const Student& lhs, const Student& rhs) const { return lhs.mId < rhs.mId; } }; int main() { // Set of Student class objects std::set<Student, StudentComp> setOfStudents = { Student(1, "Shaun"), Student(2, "Riti"), Student(3, "Aadi"), Student(4,"Vicky"), Student(5, "Renu") }; // Find a student with id 3 std::set<Student, StudentComp>::iterator it = setOfStudents.find( Student(3, "")); // Check if Iterator is valid if (it != setOfStudents.end()) { // Modify the mutuable content which is not // used in comparision or indexing it->mName = "Aarav"; std::cout << it->mId << " :: " << it->mName << std::endl; } // Check if a student with ID 3 exists in set // Not possible to fetch the iterator with count(), // It returns the count only if (setOfStudents.count(Student(3, "")) != 0) { std::cout << it->mId << " Exist in Set" << std::endl; } return 0; }
#include <iostream> #include <set> #include <string> #include <algorithm> #include <iterator> // Student with ID and name // Name is mutable, so can be modified by const object struct Student { int mId; mutable std::string mName; Student(int id, std::string name) : mId(id), mName(name) { } }; // Student comparator / Functor // Compare objects with ID only struct StudentComp { bool operator()(const Student& lhs, const Student& rhs) const { return lhs.mId < rhs.mId; } }; int main() { // Set of Student class objects std::set<Student, StudentComp> setOfStudents = { Student(1, "Shaun"), Student(2, "Riti"), Student(3, "Aadi"), Student(4,"Vicky"), Student(5, "Renu") }; // Find a student with id 3 std::set<Student, StudentComp>::iterator it = setOfStudents.find( Student(3, "")); // Check if Iterator is valid if (it != setOfStudents.end()) { // Modify the mutuable content which is not // used in comparision or indexing it->mName = "Aarav"; std::cout << it->mId << " :: " << it->mName << std::endl; } // Check if a student with ID 3 exists in set // Not possible to fetch the iterator with count(), // It returns the count only if (setOfStudents.count(Student(3, "")) != 0) { std::cout << it->mId << " Exist in Set" << std::endl; } return 0; }
Output:
3 :: Aarav 3 Exist in Set
Множество — это структура данных, эквивалентная множествам в математике. Множество состоит из различных элементов заданного типа и поддерживает операции добавления элемента в множество, удаления элемента из множества, проверка принадлежности элемента множеству. Одно и то же значение хранится в множестве только один раз.
Для представления множеств в библиотеке STL имеется контейнер set
, который реализован при помощи сбалансированного двоичного дерева поиска (красно-черного дерева), поэтому множества в STL хранятся в виде упорядоченной структуры, что позволяет перебирать элементы множества в порядке возрастания их значений. Для использования контейнера set
нужно подключить заголовочный файл <set>
.
Подробней о возможностях контейнера set
можно прочитать, например, на сайте cppreference.com.
В простейшем случае множество, например, данных типа int
объявляется так:
set <int> S;
Для добавления элемента в множество используется метод insert
:
S.insert(x);
Для проверки принадлежности элемента множеству используется метод count
. Этот метод возвращает количество вхождения передаваемого параметра в данный контейнер, но поскольку в множестве все элементы уникальные, то count
для типа set
всегда возвращает 0 или 1. То есть для проверки принадлежности значения x
множеству S
можно использовать следующий код:
if (S.count(x)) { …
Для удаления элемента используется метод erase
. Ему можно передать значение элемента, итератор, указывающий на элемент или два итератора (в этом случае удаляется целый интервал элементов, содержащийся между заданными итераторами). Вот два способа удалить элемент x
:
S.erase(x);
S.erase(S.find(x));
Метод size()
возвращает количество элементов в множестве, метод empty()
, возвращает логическое значение, равное true
, если в множестве нет элементов, метод clear()
удаляет все элементы из множества.
Итераторы
С итераторами контейнера set
можно выполнять операции инкремента (что означает переход к следующему элементу) и декремента (переход к предыдущему элементу). Итераторы можно сравнивать на равенство и неравенство. Операции сравнения итераторов при помощи “<“, “<=”, “>”, “>=” невозможны, также невозможно использовать операции прибавления к итератору числа.
Разыменование итератора (применение унарного оператора *
) возвращает значение элемента множества, на который указывает итератор.
У множества есть метод begin()
, который возвращает итератор на первый элемент множества, и метод e
nd()
, который возвращает фиктивный итератор на элемет, следующий за последним элементом в множестве. Таким образом, вывести все элементы множества можно так:
set <int> S;
set <int>::iterator it;
for (it = S.begin(); it != S.end(); ++it)
cout << *it << ” “
Благодаря тому, что множества хранятся в упорядоченном виде, все элементы будут выведены в порядке возрастания значений.
В стандарте C++11 разрешается перебор всех элементом множества при помощи range-based цикла:
for (auto elem: S)
cout << elem << ” “;
Элементы также будут выведены в порядке возрастания.
Для вывода элементов в порядке убывания можно использовать reverse_iterator аналогично векторам:
for (auto it = S.rbegin(); it != S.rend(); ++it)
cout << *it << ” “;
Функции удаления элементов могут принимать итератор в качестве параметра. В этом случае удаляется элемент, на который указывает итератор. Например, чтобы удалить наименьший элемент:
S.erase(S.begin());
Но для удаления последнего (наибольшего) элемента в set нельзя использовать reverse_iterator, нужно взять обычный итератор, указывающий на end(), уменьшить и удалить:
auto it = S.begin();
–it;
S.erase(it);
Поиск элемента в set
Для поиска конкретного элемента в set используется метод find
. Этот метод возвращает итератор на элемент, а если элемент не найден, то он возвращает итератор end()
(т.е. на фиктивный элемент, следующий за последним элементом множества. Используя этот метод проверить принадлежность элемента множеству можно так:
if (S.find(x) != S.end()) { …
Также есть методы lower_bound и upper_bound, которые находят первых элемент, больше или равный x и первый элемент, строго больший x (аналогично двоичному поиску элемента в массиве).
Эти методы также возвращают итераторы, а если таких элементов (больше или равных или строго больших) нет в множестве, они возвращают end().
Например, удалить из set минимальный элемент, строго больший x можно так:
auto it = S.upper_bound(x);
if (it != S.end())
S.erase(it);
Множества в Python – это структура данных, которые содержат неупорядоченные элементы. Элементы также не является индексированным. Как и список, множество позволяет внесение и удаление элементов. Однако, есть ряд особенных характеристик, которые определяют и отделяют множество от других структур данных:
- Множество не содержит дубликаты элементов;
- Элементы множества являются неизменными (их нельзя менять), однако само по себе множество является изменяемым, и его можно менять;
- Так как элементы не индексируются, множества не поддерживают никаких операций среза и индексирования.
В этой статье мы обсудим различные операции, которые можно применять на множествах в Python.
Содержание:
- Создание множеств
- Доступ к элементам множеств
- Добавление элементов во множество
- Удаление элементов из множеств
- Объединение множеств
- Пересечение множеств
- Разница множеств
- Сравнение множеств
- Методы множеств
- Frozenset в Python
- Вывод
Создание множеств
Существует два пути, следуя которым, мы можем создавать множества в Python.
Есть вопросы по Python?
На нашем форуме вы можете задать любой вопрос и получить ответ от всего нашего сообщества!
Telegram Чат & Канал
Вступите в наш дружный чат по Python и начните общение с единомышленниками! Станьте частью большого сообщества!
Паблик VK
Одно из самых больших сообществ по Python в социальной сети ВК. Видео уроки и книги для вас!
Мы можем создать множество путем передачи всех элементов множества внутри фигурных скобок {}
и разделить элементы при помощи запятых (,)
. Множество может содержать любое количество элементов и элементы могут быть разных типов, к примеру, целые числа, строки, кортежи, и т. д. Однако, множество не поддерживает изменяемые элементы, такие как списки, словари, и так далее.
Рассмотрим пример создания множества в Python:
num_set = {1, 2, 3, 4, 5, 6} print(num_set) |
Результат:
Только что мы создали множество чисел. Мы также можем создать множество из строк. Например:
string_set = {“Nicholas”, “Michelle”, “John”, “Mercy”} print(string_set) |
Результат:
{‘Michelle’, ‘Nicholas’, ‘John’, ‘Mercy’} |
Возможно вы обратили внимание на то, что элементы в выдаче выше находятся в другом порядке, отличном от того, как мы добавляли их в множество. Это связано с тем, что элементы множества находятся в произвольном порядке. Если вы запустите тот же код еще раз, возможно вы получите выдачу с элементами, которые каждый раз будут находиться в другом порядке.
Мы также можем создать множество с элементами разных типов. Например:
mixed_set = {2.0, “Nicholas”, (1, 2, 3)} print(mixed_set) |
Результат:
{2.0, ‘Nicholas’, (1, 2, 3)} |
Все элементы в упомянутом выше множестве принадлежат разным типам.
Мы также можем создать множество из списков. Это можно сделать, вызвав встроенную функцию Python под названием set()
. Например:
num_set = set([1, 2, 3, 4, 5, 6]) print(num_set) |
Результат:
Как упоминалось ранее, множества не содержат дубликаты элементов. Предположим, наш список содержит дубликаты элементов, как показано ниже:
num_set = set([1, 2, 3, 1, 2]) print(num_set) |
Результат:
Множество удалило дубликаты и выдало только по одному экземпляру элементов. Это также происходит при создании множества с нуля. Например:
num_set = {1, 2, 3, 1, 2} print(num_set) |
Результат:
И снова, множество удалило дубликаты и вернуло только один из дублируемых объектов.
Создание пустого множества подразумевает определенную хитрость. Если вы используете пустые фигурные скобки {}
в Python, вы скорее создадите пустой словарь, а не множество. Например:
Результат:
Как показано в выдаче, тип переменной х
является словарем.
Чтобы создать пустое множество в Python, мы должны использовать функцию set()
без передачи какого-либо значения в параметрах, как показано ниже:
Результат:
Выдача показывает, что мы создали множество.
Доступ к элементам множеств
Python не предоставляет прямой способ получения значения к отдельным элементам множества. Однако, мы можем использовать цикл для итерации через все элементы множества. Например:
months = set([“Jan”, “Feb”, “March”, “Apr”, “May”, “June”, “July”, “Aug”, “Sep”, “Oct”, “Nov”, “Dec”]) for m in months: print(m) |
Результат:
March Feb Dec Jan May Nov Oct Apr June Aug Sep July |
Мы также можем проверить наличие элемента во множестве при помощи in
, как показано ниже:
months = set([“Jan”, “Feb”, “March”, “Apr”, “May”, “June”, “July”, “Aug”, “Sep”, “Oct”, “Nov”, “Dec”]) print(“May” in months) |
Результат:
Код возвращает «True«, а это означает, что элемент был найден во множестве. Аналогичным образом, при поиске элемента, который отсутствует во множестве, мы получим «False«, как показано ниже:
months = set([“Jan”, “Feb”, “March”, “Apr”, “May”, “June”, “July”, “Aug”, “Sep”, “Oct”, “Nov”, “Dec”]) print(“Nicholas” in months) # False |
Как и ожидалось, код вернул «False«.
Добавление элементов во множество
Python позволяет нам вносить новые элементы во множество при помощи функции add()
. Например:
months = set([“Jan”, “March”, “Apr”, “May”, “June”, “July”, “Aug”, “Sep”, “Oct”, “Nov”, “Dec”]) months.add(“Feb”) print(months) |
Результат:
{‘Oct’, ‘Dec’, ‘Feb’, ‘July’, ‘May’, ‘Jan’, ‘June’, ‘March’, ‘Sep’, ‘Aug’, ‘Nov’, ‘Apr’} |
Элемент «Feb» успешно внесен во множество. Если это было множество чисел, мы не можем передать новый элемент внутри скобочек, как мы делаем это для строк. Например:
num_set = {1, 2, 3} num_set.add(4) print(num_set) |
Результат:
В следующем разделе мы обсудим, как удалять элементы из множеств.
Удаление элемента из множеств
Python позволяет нам удалять элемент из множества, но не используя индекс, так как множество элементов не индексированы. Элементы могут быть удалены при помощи обоих методов discard()
и remove()
.
Помните, что метод discard()
не будет выдавать ошибку, если элемент не был найден во множестве. Однако, если метод remove()
используется и элемент не был найден, возникнет ошибка.
Давайте продемонстрируем как удалять элемент при помощи метода discard()
:
num_set = {1, 2, 3, 4, 5, 6} num_set.discard(3) print(num_set) |
Результат:
Элемент 3
был удален из множества.
Аналогично, метод remove()
может использоваться следующим образом:
num_set = {1, 2, 3, 4, 5, 6} num_set.remove(3) print(num_set) |
Результат:
Теперь попробуем удалить элемент, которого нет во множестве. Сначала используем метод discard()
:
num_set = {1, 2, 3, 4, 5, 6} num_set.discard(7) print(num_set) |
Результат:
Выдача выше показывает, что никакого воздействия на множество не было оказано. Теперь посмотрим, что выйдет из использования метода remove()
по аналогичному сценарию:
num_set = {1, 2, 3, 4, 5, 6} num_set.remove(7) print(num_set) |
Результат:
Traceback (most recent call last): File “C:Usersadminsets.py”, line 2, in <module> num_set.remove(7) KeyError: 7 |
Выдача показывает, что метод выдал ошибку KeyError, так как мы пытались удалить элемент, которого нет во множестве.
С методом pop()
, мы можем удалить и вернуть элемент. Так как элементы находятся в произвольном порядке, мы не можем утверждать или предсказать, какой элемент будет удален.
Например:
num_set = {1, 2, 3, 4, 5, 6} print(num_set.pop()) |
Результат:
Вы можете использовать тот же метод при удалении элемента и возврате элементов, которые остаются во множестве. Например:
num_set = {1, 2, 3, 4, 5, 6} num_set.pop() print(num_set) |
Результат:
Эти элементы остаются во множестве.
Метод Python под названием clear()
поможет удалить все элементы во множестве. Например:
num_set = {1, 2, 3, 4, 5, 6} num_set.clear() print(num_set) |
Результатом является пустой set()
без каких-либо элементов внутри.
Объединение множеств
Предположим, у нас есть два множества, А и В. Объединение этих двух множеств — это множество со всеми элементами обеих множеств. Такая операция выполняется при помощи функции Python под названием union()
.
Рассмотрим пример:
months_a = set([“Jan”, “Feb”, “March”, “Apr”, “May”, “June”]) months_b = set([“July”, “Aug”, “Sep”, “Oct”, “Nov”, “Dec”]) all_months = months_a.union(months_b) print(all_months) |
Результат:
{‘Oct’, ‘Jan’, ‘Nov’, ‘May’, ‘Aug’, ‘Feb’, ‘Sep’, ‘March’, ‘Apr’, ‘Dec’, ‘June’, ‘July’} |
Объединение может состоять из более чем двух множеств, и все их элементы сложатся в одно большое множество. Например:
x = {1, 2, 3} y = {4, 5, 6} z = {7, 8, 9} output = x.union(y, z) print(output) |
Результат:
{1, 2, 3, 4, 5, 6, 7, 8, 9} |
При выполнении операции объединения, дубликаты игнорируются, так что только один из двух элементов дубликатов будет отображаться. Например:
x = {1, 2, 3} y = {4, 3, 6} z = {7, 4, 9} output = x.union(y, z) print(output) |
Результат:
Оператор |
может также использоваться при поиске объединения двух или более множеств. Например:
months_a = set([“Jan”,“Feb”, “March”, “Apr”, “May”, “June”]) months_b = set([“July”, “Aug”, “Sep”, “Oct”, “Nov”, “Dec”]) print(months_a | months_b) |
Результат:
{‘Feb’, ‘Apr’, ‘Sep’, ‘Dec’, ‘Nov’, ‘June’, ‘May’, ‘Oct’, ‘Jan’, ‘July’, ‘March’, ‘Aug’} |
Если вы хотите создать объединение из более двух множеств, разделите названия множеств при помощи оператора |
. Взглянем на пример:
x = {1, 2, 3} y = {4, 3, 6} z = {7, 4, 9} print(x | y | z) |
Результат:
Пересечение множеств
Предположим, у вас есть два множества: А и В. Их пересечение представляет собой множество элементов, которые являются общими для А и для В.
Операция пересечения во множествах может быть достигнута как при помощи оператора &
, так и метода intersection()
. Рассмотрим пример:
x = {1, 2, 3} y = {4, 3, 6} print(x & y) # Результат: 3 |
В обеих множествах 3
является общим элементом. То же самое может быть достигнуто при использовании метода intersection()
:
x = {1, 2, 3} y = {4, 3, 6} z = x.intersection(y) print(z) # Результат: 3 |
В следующем разделе мы обсудим, как определить разницу между множествами.
Разница между множествами
Предположим, у вас есть два множества: А и В. Разница между А и В (А — В) — это множество со всеми элементами, которые содержатся в А, но не в В. Соответственно, (В — А) — это множество со всеми элементами в В, но не в А.
КОД
Для определения разницы между множествами в Python, мы можем использовать как функцию difference(), так и оператор — . Рассмотрим пример:
set_a = {1, 2, 3, 4, 5} set_b = {4, 5, 6, 7, 8} diff_set = set_a.difference(set_b) print(diff_set) |
Результат:
В показанном выше скрипте, только первые три элемента множества set_a
отсутствуют во множестве set_b
, формируя нашу выдачу. Оператор минус -
можно также применить для нахождения разницы между двумя множествами, как показано ниже:
set_a = {1, 2, 3, 4, 5} set_b = {4, 5, 6, 7, 8} print(set_a – set_b) |
Результат:
Симметричная разница между множествами А и В — это множество с элементами, которые находятся в А и В, за исключением тех элементов, которые являются общими для обеих множеств. Это определяется использованием метода Python под названием symmetric_difference()
, или оператора ^
. Посмотрим на пример:
set_a = {1, 2, 3, 4, 5} set_b = {4, 5, 6, 7, 8} symm_diff = set_a.symmetric_difference(set_b) print(symm_diff) |
Результат:
Симметричную разницу можно также найти следующим образом:
set_a = {1, 2, 3, 4, 5} set_b = {4, 5, 6, 7, 8} print(set_a ^ set_b) |
Результат:
Сравнение множеств
Мы можем сравнить множества в зависимости от того, какие элементы в них содержатся. Таким образом, мы можем сказать, является ли множество родительским, или дочерним от другого множества. Результат такого сравнения будет либо True
, либо False
.
Чтобы проверить, является ли множество А дочерним от В, мы можем выполнить следующую операцию:
Чтобы узнать является ли множество В дочерним от А, мы можем выполнить следующую операцию, соответственно:
Например:
months_a = set([“Jan”, “Feb”, “March”, “Apr”, “May”, “June”]) months_b = set([“Jan”, “Feb”, “March”, “Apr”, “May”, “June”, “July”, “Aug”, “Sep”, “Oct”, “Nov”, “Dec”]) subset_check = months_a <= months_b superset_check = months_b >= months_a print(subset_check) print(superset_check) |
Результат:
Дочернее и родительское множество может также быть проверено при помощи методов issubset()
и issuperset()
, как показано ниже:
months_a = set([“Jan”,“Feb”, “March”, “Apr”, “May”, “June”]) months_b = set([“Jan”,“Feb”, “March”, “Apr”, “May”, “June”, “July”, “Aug”, “Sep”, “Oct”, “Nov”, “Dec”]) subset_check = months_a.issubset(months_b) superset_check = months_b.issuperset(months_a) print(subset_check) print(superset_check) |
Результат:
В следующем разделе мы обсудим некоторые из наиболее часто используемых методов для манипуляции множествами, предоставленных в Python, которые мы не успели упомянуть.
Методы множеств
Python содержит огромное количество встроенных методов, включая следующие:
Метод copy()
Этот метод возвращает копию множества. Например:
string_set = {“Nicholas”, “Michelle”, “John”, “Mercy”} x = string_set.copy() print(x) |
Результат:
{‘John’, ‘Michelle’, ‘Nicholas’, ‘Mercy’} |
Выдача показывает, что х
является копией множества string_set
.
Метод isdisjoint()
Этот метод проверяет, является ли множество пересечением или нет. Если множества не содержат общих элементов, метод возвращает True
, в противном случае — False
. Например:
names_a = {“Nicholas”, “Michelle”, “John”, “Mercy”} names_b = {“Jeff”, “Bosco”, “Teddy”, “Milly”} x = names_a.isdisjoint(names_b) print(x) |
Результат:
Оба множества не имеют общих элементов, что делает выдачу True
.
Метод len()
Этот метод возвращает длину множества, которая является общим количеством элементов во множестве. Пример:
names_a = {“Nicholas”, “Michelle”, “John”, “Mercy”} print(len(names_a)) # Результат: 4 |
Выдача показывает, что длина множества является 4.
Frozenset в Python
Frozenset (замороженное множество) – это класс с характеристиками множества, однако, как только элементы становятся назначенными, их нельзя менять. Кортежи могут рассматриваться как неизменяемые списки, в то время как frozenset-ы — как неизменные множества.
Множества являются изменяемыми и нехешируемыми, это значит, что мы не можем использовать их как словарные ключи. Замороженные множества (frozenset) являются хешированными и могут использоваться в качестве ключей словаря.
Для создания замороженного множества, мы используем метод frozenset()
. Давайте создадим два замороженных множества, Х и Y:
X = frozenset([1, 2, 3, 4, 5, 6]) Y = frozenset([4, 5, 6, 7, 8, 9]) print(X) print(Y) |
Результат:
frozenset({1, 2, 3, 4, 5, 6}) frozenset({4, 5, 6, 7, 8, 9}) |
Замороженные множества поддерживают использование множественных методов Python, таких как copy()
, difference()
, symmetric_difference()
, isdisjoint()
, issubset()
, intersection()
, issuperset()
и union()
.
Вывод
Данная статья предоставляет подробное введение во множества языка программирования Python. Математическое определение множеств аналогично определению множеств в Python.
Множество — это набор элементов в произвольном порядке. Само по себе, множество является изменяемым, однако его элементы являются неизменяемыми.
Однако, мы можем добавлять и убирать элементы из множества без каких-либо проблем. В большей структур данных элементы являются индексированными. Однако, элементы множеств не являются индексированными. Это делает невозможным для нас выполнять операции, которые направлены на определенные элементы множества.
Являюсь администратором нескольких порталов по обучению языков программирования Python, Golang и Kotlin. В составе небольшой команды единомышленников, мы занимаемся популяризацией языков программирования на русскоязычную аудиторию. Большая часть статей была адаптирована нами на русский язык и распространяется бесплатно.
E-mail: vasile.buldumac@ati.utm.md
Образование
Universitatea Tehnică a Moldovei (utm.md)
- 2014 — 2018 Технический Университет Молдовы, ИТ-Инженер. Тема дипломной работы «Автоматизация покупки и продажи криптовалюты используя технический анализ»
- 2018 — 2020 Технический Университет Молдовы, Магистр, Магистерская диссертация «Идентификация человека в киберпространстве по фотографии лица»