// PascalABC.NET 3.6.3
uses School;
function Divizors(n: integer): List<integer>;
begin
var L := new List<integer>;
L.Add(1);
L.Add(n);
if n > 3 then
begin
var k := 2;
while (k * k <= n) and (k < 46341) do
begin
if n mod k = 0 then
begin
var t := n div k;
L.Add(k);
if k < t then L.Add(t)
else break
end;
Inc(k)
end;
L.Sort;
end;
Result := L
end;
begin
// 1
if ReadInteger.IsPrime then Println('YES')
else Println('NO');
// 2
ReadInteger.Factorize.First.Println;
// 3
var a := Divizors(ReadInteger);
Print(a.Count, a.Sum)
end.
import random
def func_decorator(function): # Функция декоратор
def inner_func():
func = function() # Присваиваем результат функции random_list в переменную func
b = [] # Создаём пустой список для сортировки
for i in func :
if i in b:
continue # Если значение уже присутствует в списке, мы его пропускаем
elif not i in b:
b.append(i) # Если значения нету в списке, мы его добавляем
return b
return inner_func
@func_decorator
def random_list():
return random.choices(range(10, 51), k = 100)
# @func_decorator это тоже самое что и: random_list = func_decorator (random_list)
# random.choices (population, k=1). Возвращает список элементов размером k , выбранных из последовательности population
print(random_list())
Вот мой вариант решения)