// 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.
В строке 1 импортируем из библиотеки random функцию randint, которая позволяет сгенерировать целое число.
В строках 3 и 4 генерируем по числу, в дальнейшем это будет максимальное количество элементов в массиве.
В строке 6 объявляем 2 списка (list1, list2).
В строках 8-12 создаем цикл в котором генерируем числа в массив (list1) и в блоке if проверяем кратны ли они трем.
В строках 14-18 проворачиваем те же действия, только значения заносим в другой массив (list2).
В строке 20 объявляем множество (set1).
В строке 21 присваиваем значения с обоих массивов (list1, list2) множеству (set1).
В строке 23 объявляем массив (endlist) в который мы заносим все числа с множества (set1).
В строках 25-28 просто проверяем работо (не обязательно).