Сгенерировать пароль из ? кол-во символов. Python. Эту задачу я уже решал, просто мне интересно, на сколько полезен данный сервис. ТЗ:
1. Должна быть программа (консольная), которая не обязательно должна иметь дизайн, и должна использовать только одну библиотеку (random).
2. По началу, программа спросит пользователя, длину пароля.
3. Если длина не число
3.1. Вывести об этом ошибку
3.2. Вернуться к началу, и снова спросить пользователя длину.
4. Если длина число
4.1. Сгенерировать пароль, длинной которую ввёл пользователь.
4.2. Выдать сгенерированный пароль в консоль.
4.3. Вернуться к началу, и снова спросить пользователя длину.
Готовые символы, которые могут быть в сгенерированном пароле:
[email protected]$%^&*()_-+
Желательно, чтобы код не занимал более 20 строк.
Если кому-то такая задача не под силу, напишите об этом. Я могу предоставить свой вариант решения, который ранее опубликовал на GitHub, чтобы вы смогли научиться решать такую задачу.
const n=100;
var ar:array of array of integer;
ars:array of array of string;
i:integer;
procedure complection(var ar:array of array of integer;var ars:array of array of string);
var
i,j:integer;
begin;
for i:=1 to n do
begin;
for j:=1 to n do
begin;
ar[i,j]:=random(9);
str(ar[i,j],ars[i,j]);
end;
end;
end;
procedure burning(ars:array of array of string);
var
i,j:integer;
t:text;
begin;
assign(t,'text.txt');
rewrite(t);
for i:=1 to n do
begin;
writeln(t,' ');
for j:=1 to n do
write(t,ars[i,j],' ');
end;
end;
begin;
randomize;
setlength(ar,n+1);
setlength(ars,n+1);
for i:=1 to n do
begin;
setlength(ar[i],n+1);
setlength(ars[i],n+1);
end;
complection(ar,ars);
burning(ars);
end.
const
MAX_SIZE = 100;
var
size, n: integer;
stack: array[1..MAX_SIZE] of integer;
procedure push(a: integer);
begin
inc(size);
stack[size] := a;
end;
procedure view;
var
i: integer;
begin
for i := 1 to size do
write(stack[i], ' ');
writeln;
end;
Для очереди:
const
MAX_SIZE = 100;
var
head, tail: integer;
queue: array[1..MAX_SIZE] of integer;
procedure push(a: integer);
begin
queue[tail] := a;
inc(tail);
end;
procedure view;
var
i: integer;
begin
for i := head to tail - 1 do
write(queue[i], ' ');
writeln;
end;
И стек и очередь реализованы с массива. Нужно следить, чтобы размер структуры не был больше размера массива