Первая строчка спрашивает у человека адрес файла. После ввода получается подобная строчка: "C:\Users\usr\password.txt"
Но там есть такая штука ".split('/')"
Суть её в том, что она разделяет строку и суёт части в массив. В скобках пишется сам разделитель. Если в скобках ничего нет, то разделителем служит пробел. Если выполнить
'hello world guys yes no'.split()
то получим в итоге массив
['hello', 'world', 'guys', 'yes', 'no']
В твоём случае разделителем служит "/". Если ты хотел разделить адрес на составляющие, нужно использовать слеш в другую сторону.
Тут строчка
'C:\Users\usr\password.txt'.split('/')
превратиться в
['C:\Users\usr\password.txt']
То есть не разделиться.
Я думаю задумывалось вот так:
'C:\Users\usr\password.txt'.split('\')
выйдет
['C:', 'Users', 'usr', 'password.txt']
Будем отталкиваться от моего варианта.
Далее идёт цикл for. В нашем случае в цикле for "i" будет равна числу от 0, до кол-ва объектов в массиве.
len(a) - даёт кол-во объектов в массиве.
in range - проходит по числам в определенном диапазоне. Если стоит одно число, то проходится от 0 до него (если число 3, то проходится по числам 0,1,2). Если два числа, то проходится от первого до второго с шагом один (если числа 2 и 5, то проходится по числам 2,3,4). Третье число (все числа записываются через запятую) будет означать шаг. in range(0,40,10) пройдётся по числам 0, 10, 20, 30.
В нашем случае in range проходится по кол-ву объектов в массиве.
В следующей строчке выводится "a[i]". a - это наш массив. i - порядковый номер объекта в массиве (стоит помнить, что массив начинает счёт не с 1, а с 0. Т. е. 0 объект - это первый объект.)
Если в код засунуть путь до файла, то в итоге он тебе выведет каждую часть путя.
Первая строчка спрашивает у человека адрес файла. После ввода получается подобная строчка: "C:\Users\usr\password.txt"
Но там есть такая штука ".split('/')"
Суть её в том, что она разделяет строку и суёт части в массив. В скобках пишется сам разделитель. Если в скобках ничего нет, то разделителем служит пробел. Если выполнить
'hello world guys yes no'.split()
то получим в итоге массив
['hello', 'world', 'guys', 'yes', 'no']
В твоём случае разделителем служит "/". Если ты хотел разделить адрес на составляющие, нужно использовать слеш в другую сторону.
Тут строчка
'C:\Users\usr\password.txt'.split('/')
превратиться в
['C:\Users\usr\password.txt']
То есть не разделиться.
Я думаю задумывалось вот так:
'C:\Users\usr\password.txt'.split('\')
выйдет
['C:', 'Users', 'usr', 'password.txt']
Будем отталкиваться от моего варианта.
Далее идёт цикл for. В нашем случае в цикле for "i" будет равна числу от 0, до кол-ва объектов в массиве.
len(a) - даёт кол-во объектов в массиве.
in range - проходит по числам в определенном диапазоне. Если стоит одно число, то проходится от 0 до него (если число 3, то проходится по числам 0,1,2). Если два числа, то проходится от первого до второго с шагом один (если числа 2 и 5, то проходится по числам 2,3,4). Третье число (все числа записываются через запятую) будет означать шаг. in range(0,40,10) пройдётся по числам 0, 10, 20, 30.
В нашем случае in range проходится по кол-ву объектов в массиве.
В следующей строчке выводится "a[i]". a - это наш массив. i - порядковый номер объекта в массиве (стоит помнить, что массив начинает счёт не с 1, а с 0. Т. е. 0 объект - это первый объект.)
Если в код засунуть путь до файла, то в итоге он тебе выведет каждую часть путя.
Если C:\Users\usr\password.txt, то код напишет
C:
Users
usr
password.txt
Пиши, если есть вопросы.
Посмотрим в таблицу. Максимальное количество знаков для кодирования -- 3, значит и расшифровывать надо, используя по три знака.
Запись начинается с ###, такого знака в таблице нет, но есть ##, или С.
После С идут три знака: #@@, такой буквы снова нет, тогда отсекаем последний знак: #@, это обозначение F.
Следующие далее три знака @## снова не имеют буквы в таблице, значит берём только первые 2: @# -- буква А.
И последние три знака #@# это обозначение буквы М.
Таким образом зашифрованное слово -- CFAM