
Вопрос задан 17.07.2023 в 20:24.
Предмет Информатика.
Спрашивает Aleinikova Margheret.
Доступ к управлению кораблем защищен надежным паролем и системой защиты от брутфорса (программ
взлома паролей). Принцип работы системы прост: как только космический пират выполнил N попыток перебора – пароль самопроизвольно увеличивается в длине, добавлением в конец одного символа – последнего знака алфавита. Определить время, необходимое взломщику на подбор пароля с такой защитой, если каждый вариант пароля проверяется за 1 миллисекунду, если пират производит полный перебор возможных вариантов, начиная с первого знака алфавита и движется в алфавитном порядке. Формат входных данных: На вход программе подается строка - алфавит из которого могут составляться пароли, затем строка, состоящая из символов выбранного алфавита (длины строк не более 256 символов) - составленный пароль и число N - количество попыток ввода пароля, после которого пароль самопроизвольно увеличивается, где N больше мощности алфавита. Формат выходных данных: одно число – время в миллисекундах взлома данного пароля полым перебором.

Ответы на вопрос

Отвечает Будякова Анастасия.
Ответ:
Пацан, земля пухом, мы тоже сидим уже час решить это не можем
Объяснение:
Я хз ваще, слишком сложна, паскаль сложный, С++ лучше, но я его не знаю((9(9



Отвечает нейросеть ChatGpt. Будьте внимательны, ответы нейросети могут содержать ошибочные или выдуманные данные.
Для решения этой задачи мы можем использовать следующий алгоритм:
- Получить входные данные: алфавит, пароль и число N.
- Определить длину пароля.
- Определить мощность алфавита (количество символов).
- Вычислить количество вариантов пароля для каждой длины, начиная с длины текущего пароля и увеличивая его на 1 каждый раз, когда число попыток перебора достигает или превышает N.
- Вычислить общее количество вариантов пароля для всех длин.
- Вычислить время взлома, умножив общее количество вариантов пароля на 1 миллисекунду (время проверки одного варианта).
- Вернуть время взлома.
Вот пример реализации этого алгоритма на языке Python:
pythondef password_cracking_time(alphabet, password, N):
password_length = len(password)
alphabet_size = len(alphabet)
total_combinations = 0
while password_length <= N:
total_combinations += alphabet_size ** password_length
password_length += 1
cracking_time = total_combinations * 1 # 1 миллисекунда на проверку одного варианта пароля
return cracking_time
# Пример использования
input_alphabet = input() # Введите алфавит, например, "abcdefghijklmnopqrstuvwxyz"
input_password = input() # Введите пароль, например, "abcd"
input_N = int(input()) # Введите число N, например, 100
time = password_cracking_time(input_alphabet, input_password, input_N)
print(time)
Программа будет просить вас ввести алфавит, пароль и число N, а затем выведет время взлома в миллисекундах. Обратите внимание, что символы в алфавите и пароле должны быть разделены пробелами или запятыми.


Похожие вопросы
Топ вопросов за вчера в категории Информатика

Информатика 47

Информатика 33

Информатика 67

Информатика 18

Информатика 25

Информатика 563

Информатика 16
Последние заданные вопросы в категории Информатика
Предметы
-
Математика
-
Литература
-
Алгебра
-
Русский язык
-
Геометрия
-
Английский язык
-
Химия
-
Физика
-
Биология
-
Другие предметы
-
История
-
Обществознание
-
Окружающий мир
-
География
-
Українська мова
-
Информатика
-
Українська література
-
Қазақ тiлi
-
Экономика
-
Музыка
-
Право
-
Беларуская мова
-
Французский язык
-
Немецкий язык
-
МХК
-
ОБЖ
-
Психология
-
Физкультура и спорт
-
Астрономия
-
Кыргыз тили
-
Оʻzbek tili