function ЧислоДелителей(Self: integer): integer;
extensionmethod;
begin
Result := 2; // на себя и на 1 число всегда делится
for var i := 2 to Self div 2 do
if Self mod i = 0 then Inc(Result)
end;
var (НижняяГрапница, ВерхняяГраница) :=
ReadInteger2('Укажите границы диапазона:');
var ТребуетсяДелителей :=
ReadInteger('Укажите количество делителей:');
Range(НижняяГрапница, ВерхняяГраница)
.Where(t -> t.ЧислоДелителей = ТребуетсяДелителей).Count.Print
end.
var n := ReadInteger;
var a := arrRandom(n, 1, 100);
a.Println;
var p := BigInteger(1);
for var i := 0 to n - 1 do
if a[i] mod 2 = 0 then p := p * a[i];
p.Println
67 13 96 10 94 24 16 2 43 94 60 60 56 88 28 27 75 32 90 18 70 32 6 23 81 57 38 73 25 6 20 52 56 33 38 79 20 81 67 49 33 29 43 36 74 46 13 14 30 93 72 8 10 99 89 35 8 73 30 37 86 43 78 38 75 9 4 24 50 49 8 95 65 42 85 42 90 71 50 35 45 25 44 33 34 13 43 57 45 4
function ЧислоДелителей(Self: integer): integer;
extensionmethod;
begin
Result := 2; // на себя и на 1 число всегда делится
for var i := 2 to Self div 2 do
if Self mod i = 0 then Inc(Result)
end;
begin
var (НижняяГрапница, ВерхняяГраница) :=
ReadInteger2('Укажите границы диапазона:');
var ТребуетсяДелителей :=
ReadInteger('Укажите количество делителей:');
Range(НижняяГрапница, ВерхняяГраница)
.Where(t -> t.ЧислоДелителей = ТребуетсяДелителей).Count.Print
end.
ПримерУкажите границы диапазона: 35 210Укажите количество делителей: 106begin
var n := ReadInteger;
var a := arrRandom(n, 1, 100);
a.Println;
var p := BigInteger(1);
for var i := 0 to n - 1 do
if a[i] mod 2 = 0 then p := p * a[i];
p.Println
end.
Пример9067 13 96 10 94 24 16 2 43 94 60 60 56 88 28 27 75 32 90 18 70 32 6 23 81 57 38 73 25 6 20 52 56 33 38 79 20 81 67 49 33 29 43 36 74 46 13 14 30 93 72 8 10 99 89 35 8 73 30 37 86 43 78 38 75 9 4 24 50 49 8 95 65 42 85 42 90 71 50 35 45 25 44 33 34 13 43 57 45 4
752729749734296001571550469794689018400554807071967543296000000000000000