
Keoldalsh
5 год назад
Дан массив N(N<=100) натуральных чисел, не превышающих 999. Расположить их по возрастанию суммы их цифр. Если у двух различных чисел суммы цифр совпадают, то первыми из них должно идти меньшее число. Срочно!!!
ОТВЕТЫ

Simen Liese
Oct 24, 2020
function SumD(n:integer):integer;
begin
Result:=0;
while n>0 do begin
Result+=n mod 10;
n:=n div 10
end
end;
begin
var a:=ArrRandom(ReadInteger('n='),1,999); a.Println;
a:=a.OrderBy(x->x).OrderBy(x->SumD(x)).ToArray;
a.Println;
end.
n= 30
632 411 647 143 933 205 451 16 213 479 106 939 299 315 566 428 306 758 495 927 101 301 599 969 368 180 24 124 739 635
101 301 24 213 411 16 106 124 205 143 180 306 315 451 632 428 635 933 368 566 647 495 927 739 299 479 758 939 599 969
70