Тема 14. Системы счисления

14.01 Арифметические выражения

Вспоминай формулы по каждой теме
Решай новые задачи каждый день
Вдумчиво разбирай решения
ШКОЛКОВО.
Готовиться с нами - ЛЕГКО!
Подтемы раздела системы счисления
Решаем задачу:

Ошибка.
Попробуйте повторить позже

Задача 1#16277

Сколько единиц содержится в двоичной записи значения выражения: 419 + 28 +31  ?

Показать ответ и решение

Решение программой

Для подсчёта количества единиц в двоичной записи числа необходимо написать алгоритм перевода исходного числа в двоичную систему счисления. Для перевода реализуем в программе стандартный алгоритм перевода числа из десятичной системы счисления в другую. Потом подсчитаем количество единиц при помощи метода count(). Также можно использовать функцию bin() для перевода числа в двоичную систему счисления.

# Способ 1
# Исходное выражение
a = 4**19 + 2**8 + 31

# Переменная для хранения числа в двоичной системе в виде строки
s = ’’

# Перевод числа из десятичной системы в двоичную
while a > 0:
    # Получаем последнюю цифру (остаток от деления на 2) и добавляем её в начало строки
    s = str(a % 2) + s
    # Отбрасываем последнюю цифру (целочисленное деление на 2)
    a //= 2

# Подсчёт и вывод количества единиц ’1’ в двоичной записи числа
print(s.count(’1’))

# Способ 2
# Прямое преобразование числа в двоичную строку с помощью bin()
a = bin(4**19 + 2**8 + 31)[2:]

# Подсчёт и вывод количества единиц ’1’ в двоичной записи числа
print(a.count(’1’))

Решение руками:

Каждое из чисел приведем к виду  k
2  . После чего внутри двоичной сс выполним все арифметические операции и получим ответ.

419 + 28 + 31 = 238 +28 + 25 − 1.

В результате сложения получаем число, в котором 3 единицы, стоящие на первом месте (считая слева), на 6 и 9 месте (считая справа). Чтобы вычесть единицу, займем из 6 разряда (считая справа) и выполним вычитание, тем самым единица на 6 месте (считая справа) заменится на 0, а стоящие за ней 5 нулей - заменятся на 1.

    100...0100100000
   -               1
    ----------------
    100...0100011111

Итого 7 единиц.

Ответ: 7

Специальные программы

Все специальные программы

Программа
лояльности v2.0

Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!

Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.

Бесплатное онлайн-обучение

Для школьников из приграничных территорий России, проживающих в ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Курской, Брянской областях и Крыму.

Налоговые вычеты

Узнай, как получить налоговый вычет при оплате обучения в «Школково».

Специальное предложение
для учителей

Бесплатный доступ к любому курсу подготовки к ЕГЭ, ОГЭ и олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!

Вернём деньги за курс
за твою сотку на ЕГЭ

Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!

cyberpunkMouse
cyberpunkMouse
Рулетка
Вы можете получить скидку в рулетке!