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

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

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

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

Задача 1#16280

Сколько единиц содержится в двоичной записи значения выражения: 82222 + 4222 − 22  ?

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

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

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

# Способ 1
# Исходное выражение
a = 8**2222 + 4**222 - 22

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

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

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

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

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

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

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

82222 + 4222 − 22 = 26666 + 2444 − 25 + 23 + 21

После применения операции сложения для первых двух чисел получим число из 6667 цифр, в котором первая цифра слева - единица и 445 цифра справа - единица, остальные - нули. Для выполнения вычитания займем из 445 разряда и вычтем число, в котором 6 цифр, первая - единица, а остальные - нули:

    100...00100...0000000
   -               100000
    ---------------------
    100...00011...1000000

Получаем, что цифра в 445 разряде справа заменится на 0, цифры от 444 до 6 разряда заменятся на 1, в 6 разряде произойдет вычитание и останется 0, последние 5 нулей останутся неизменны.

Выполним сложение, зная, что 23 = 10002,21 = 102  :

    100...00011...1000000
   +                 1010
    ---------------------
    100...00011...1001010

Итого одна единица на первом разряде слева, одна на втором разряде справа, одна на четвертом разряде справа, и 439 единиц между 444 и 6 разрядом справа. Таким образом, суммарно 442 единицы.

Ответ: 442

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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