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

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

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

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

Задача 1#63524

Пашка составляет 5-буквенные слова из букв П, А, Р, Е, К. Каждую букву нужно использовать ровно 1 раз, при этом нельзя ставить подряд две гласные или две согласные. Сколько различных кодов может составить Пашка?

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

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

В предложенном алфавите согласных букв больше чем гласных, при этом они должны чередоваться между собой. Значит, слово не может начинаться с гласной. Получаем, что набор букв должен выглядеть как «СГСГС», где С - согласная, а Г - гласная.

Так как каждая буква должна появляться в слове только 1 раз, получаем число возможных вариантов: 3 ⋅2⋅2⋅1 ⋅1 = 12.

 

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

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

s1 = "ПРК" # Согласные к задаче
s2 = "АЕ" # Гласные к задаче
cnt = 0 # Счётчик подходящих слов
# Слово, удовлетворяющее условие может выглядеть только следующим образом: СГСГС, где С - согласная буква, а Г - гласная буква.
for i in s1:
    for j in s2:
        for k in s1:
            for l in s2:
                for m in s1:
                    t = [i, j, k, l, m] # Формируем слово
                    tmp = set(t)
                    if len(tmp) == 5: # Если все буквы различны
                        cnt += 1 # Увеличим счётчик
print(cnt) # Выводим ответ

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

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

from itertools import permutations

count = set() # Множество подходящих слов

gl = "АЕ" # Гласные к задаче

for x in permutations("ПАРЕК"):
    s = "".join(x) # join объединит буквы
    # Проверка, что в слове нет подряд идуших гласных или согласных букв
    if all((s[i] in gl) != (s[i+1] in gl) for i in range(len(s)-1)):
        count.add(s) # Добавим слово в множество
print(len(count)) # Выведем нужное количество

Ответ: 12

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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