Битовые операции: различия между версиями
Материал из Algocode wiki
Глеб (обсуждение | вклад) |
Глеб (обсуждение | вклад) |
||
Строка 7: | Строка 7: | ||
$num |= (1 << i)$ | $num |= (1 << i)$ | ||
+ | ===Удалить $i$-й элемент из множества $num$, если он есть=== | ||
+ | |||
+ | $num ^= (1 << i)$ | ||
+ | |||
+ | ===Удалить $i$-й элемент из множества $num$=== | ||
+ | |||
+ | $num \&= ~(1 << i)$ | ||
{{Автор|Лобанов Глеб|glebodin}} | {{Автор|Лобанов Глеб|glebodin}} |
Версия 09:30, 13 декабря 2019
Содержание
Проверка, что $i$-й элемент в множестве $num$
$(num >> i) \& 1$ вернет 1 тогда и только тогда, когда $i$-й элемент в множестве $num$, так как $(num >> i)$ вернет нам число $num$ со сдвигом на $i$ и следовательно 1 символ будет равен 1, если элемент в множестве.
Добавить $i$-й элемент в множество $num$
$num |= (1 << i)$
Удалить $i$-й элемент из множества $num$, если он есть
$num ^= (1 << i)$
Удалить $i$-й элемент из множества $num$
$num \&= ~(1 << i)$
Автор конспекта: Лобанов Глеб
По всем вопросам пишите в telegram @glebodin