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*
Комментарий*

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

fialkaflowers77
Vladimirovna1370
Дмитрий_Владимирович1162
Микроволновые системы что это​
Lapushkina
ovdei71
expozition
smnra219
lenapopovich556510
Pilotmi247074
Elen-ti81459
Голосова-Лобанов1555
annaan-dr582
Полковников_Милана
Филиппович_Николаевич
Яковчук1911