Дан массив n(n< =100) натуральных чисел, не превышающих 999. расположить их по возрастанию суммы их цифр. если у двух различных чисел суммы цифр , то первыми из них должно идти меньшее число.

Галя4425 Галя4425    2   07.09.2019 00:20    4

Ответы
DaniilFPS DaniilFPS  16.08.2020 10:55
// PascalABC.NET 3.3, сборка 1542 от 05.10.2017
// Внимание! Если программа не работает, обновите версию!

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
ПОКАЗАТЬ ОТВЕТЫ
Другие вопросы по теме Информатика