Тема 8. Комбинаторика

8.02 Подсчет количества слов/чисел

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

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

Задача 1#53579

Определите количество семизначных чисел, записанных в восьмеричной системе счисления, в записи которых только одна цифра 1 (при этом она не может стоять на последнем месте), все цифры в записи различны.

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

Решение аналитически:

Восьмеричная система счисления содержит цифры: 0, 1, 2, 3, 4, 5, 6, 7. Существует шесть вариантов расстановки цифры 1.

1 * * * * * *

* 1 * * * * *

* * 1 * * * *

* * * 1 * * *

* * * * 1 * *

* * * * * 1 *

Также на первом месте не может стоять цифра 0, иначе полученное число будет шестизначное.

1 7 6 5 4 3 2 −→ 1*7*6*5*4*3*2=5040

6 1 6 5 4 3 2 −→ 6*1*6*5*4*3*2=4320

6 6 1 5 4 3 2 −→ 6*6*1*5*4*3*2=4320

6 6 5 1 4 3 2 −→ 6*6*5*1*4*3*2=4320

6 6 5 4 1 3 2 −→ 6*6*5*4*1*3*2=4320

6 6 5 4 3 1 2 −→ 6*6*5*4*3*1*2=4320

Итого получаем: 5040 + 5*4320 = 26640.

Решение программой с помощью циклов:

Напишем программу для перебора всевозможных комбинаций из 7 цифр. Для этого организуем 7  вложенных циклов (по одному на каждую позицию в слове). Каждый цикл перебирает цифры заданной строки, формируя все возможные комбинации. Запишем количество подходящих слов.

ans = set() # Множество подходящих комбинаций
alf = "01234567" # Цифры к задаче

for x1 in alf:
    for x2 in alf:
        for x3 in alf:
            for x4 in alf:
                for x5 in alf:
                    for x6 in alf:
                        for x7 in alf:
                            w = x1 + x2 + x3 + x4 + x5 + x6 + x7 # Формируем комбинацию
                            if len(w) == len(set(w)): # Если все цифры различны
                                if w.count("1") == 1 and w[-1] != "1" and w[0] != "0": # Проверка по условию
                                    ans.add(w) # Добавим в множество
print(len(ans)) # Выведем нужную длину

Решение программой с помощью модуля itertools:

Для решения задачи с помощью модуля itertools воспользуемся функцией permutations. Она, переставляя цифры, генерирует все возможные комбинации. Запишем количество подходящих комбинаций.

from itertools import permutations

ans = set() # Множество подходящих слов
alf = "01234567" # Цифры к задаче
# Получим все комбинации из 7 цифр
for w in permutations(alf, 7):
    w = "".join(w) # join объединяет буквы
    if w.count("1") == 1 and w[-1] != "1" and w[0] != "0": # Проверка по условию
        ans.add(w) # Добавим в множество
print(len(ans)) # Выведем нужную длину

Ответ: 26640

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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