// PascalABC.NET 3.3, сборка 1634 от 14.02.2018 // Внимание! Если программа не работает, обновите версию!
begin var fn:='MtFile.bin'; var n:=ReadInteger; var f:file of integer; var s:=SeqRandom(n,-3000,8000); // последовательность не хранится Rewrite(f,fn); foreach var m in s do Write(f,m); f.Close; // файл создан и закрыт Reset(f,fn); var b:integer; // буфер while not Eof(f) do begin Read(f,b); Print(b) end; Writeln; Seek(f,0); // стали в начало файла Read(f,b); var iOdd:=0; while not Eof(f) and b.IsEven do begin Read(f,b); iOdd+=1 end; if Eof(f) and b.IsEven then begin Writeln('Нет нечетных компонентов'); exit end; var (bb,iEven):=(b,n); repeat iEven-=1; Seek(f,iEven); Read(f,b) until (iEven=1) or b.IsEven; if b.IsOdd then begin Writeln('Нет четных компонентов'); exit end; Seek(f,iEven); Write(f,bb); Seek(f,iOdd); Write(f,b); Seek(f,0); while not Eof(f) do begin Read(f,b); Print(b) end; Writeln; f.Close end.
// 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.