Задача к ЕГЭ по информатике на тему «слова в алфавитном порядке» №19

Все 5-буквенные слова, в составе которых могут быть буквы А, С, Д, Р, Е, записаны в определённом порядке и пронумерованы, начиная с 1. Ниже приведено начало списка.

1. ААААА

2. ААААС

3. ААААД

4. ААААР

5. ААААЕ

6. АААСА

...

Сколько слов между словами “СРЕДА” и “АДРЕС”?

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

Исходя из порядка букв в списке, присвоим им следующие коды: А — 0, С — 1, Д — 2, Р — 3, Е — 4. Тогда первое слово — 00000, второе — 00001 и т.д. Слово “СРЕДА” будет кодироваться как 13420, а слово “АДРЕС”  будет кодироваться как 02341. Т.к. для кодирования слов потребовалось всего 5 разных букв, то коды будут представлены в пятеричной системе счисления. Вычтем код слова “АДРЕС”  из кода слова “СРЕДА”  и получим следующее:

    134205  −   2341 ---------5---     110245

Разница номеров слов составляет 110245 = 76410,  а значит между ними ровно 763 слова (т.к. при вычитании номеров мы учитываем на одно слово больше).

Решение Python:

from itertools import *
t = product(’АСДРЕ’, repeat = 5)
c, res1, res2 = 0, 0, 0
for i in t:
    s = ’’.join(i)
    c += 1
    if s == ’СРЕДА’:
        res1 = c
    if s == ’АДРЕС’:
        res2 = c
print(abs(res2-res1)-1)

Решение Python:

alf = ’АСДРЕ’
c = 0
res1, res2 = 0, 0
for i in alf:
    for j in alf:
        for k in alf:
            for l in alf:
                for p in alf:
                    s = i + j + k + l + p
                    c += 1
                    if s == ’СРЕДА’:
                        res1 = c
                    if s == ’АДРЕС’:
                        res2 = c
print(abs(res2-res1)-1)

Ответ: 763
Оцените статью
Я решу все!