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

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

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

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

Задача 1#11563

Сколько значащих нулей содержится в двоичной записи значения выражения: 42020 + 82021 + 162022  ?

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

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

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

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

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

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

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

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

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

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

1. Представим все слагаемые как степени двойки:

pict

2. Двоичное представление каждого слагаемого:

  • 24040 = 10◟0.◝.◜.0◞
         4040
  • 26063 = 100...0
        ◟6◝0◜63◞
  • 28088 = 100...0
        ◟8◝0◜88◞

3. Сложение в двоичной системе:

10◟0.◝.◜.0◞+1 0◟0.◝.◜.0◞+1 0◟0.◝.◜.0◞= 1  0◟0.◝.◜.0◞  +1  0◟0.◝.◜.0◞  +1 0◟0.◝.◜.0◞
  4040     6063     8088     8088−6063− 1  6063−4040−1    4040

4. Подсчёт значащих нулей:

  • Между первой и второй единицей: 8088− 6063− 1 = 2024  нуля
  • Между второй и третьей единицей: 6063− 4040− 1 = 2022  нуля
  • После третьей единицы: 4040  нулей

Общее количество значащих нулей:

2024+ 2022+ 4040 = 8086

Ответ

|----|
8086--
Ответ: 8086

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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