Tipan77
?>

Постройте круговую диаграмму по данным из табл. 3.8​

Информатика

Ответы

dvbbdv4

Код в приложении.

Пояснения:

Посмотрим, как же нам решить задачу. Сначала, поймём как обнулить бит. Бит можно обнулить если использовать логическое И с нулём. Значит, нам нужно использовать логическое И на нужном бите. Как же это сделать? В С++ есть побитовые операции между двумя числами, но побитовое И (&) применяется между всеми битами двух чисел, т.е.

101\ \& \ 110 = (1 \&1)(0\& 1)(1 \& 0) = 100

Заметим, что

a \& 0 = 0\\a \& 1 = a

Числа в С++ с фиксированной разрядностью, т.е. битов всегда определённое кол-во. Исходя из условий задачи, тут нужен int - 32-битный тип.

Тогда, чтобы обнулить нужный бит, нам нужно использовать побитовое И с таким числом, что все его биты, кроме нужного, равны 1.

Добиться этого мы сможем следующим образом. Сдвинем 1 влево на k бит и получим такое число, что все биты, кроме k-го равны 0, а k-ый равен 1, и используем побитовую инверсию (~), т.е. инвертируем каждый бит в числе.

Получив нужное число, выполняем побитовое И и обнуляем k-ый бит.

Как работают примеры:

n = 21 = 10101, \ k = 1\\n \& \sim(1

И второй пример:

n = 21 = 10101, \ k = 2\\n \& \sim (1


Условие Даны два числа N и K. Требуется изменить число N так, чтобы в K-м бите этого числа в двоично

Ответить на вопрос

Поделитесь своими знаниями, ответьте на вопрос:

Постройте круговую диаграмму по данным из табл. 3.8​
Ваше имя (никнейм)*
Email*
Комментарий*

Популярные вопросы в разделе

АртакСергеевич1723
Построить логическую схему
gurman171
Терентьева
VladimirovnaBugrova
Pavlov447
a60ikurgannikova
Владимир1524
Anatolevna1703
Vera_Shuklin
rinata542
alina-bas
arionul-secondary2
losevev5619
Nadezhdachizhikova7968
алексей-Ветошкин