Решение обязано корректно работать в PascalABC.NET, версии не выше 2.2Переставить элементы

Решение обязано корректно работать в PascalABC.NET, версии не выше 2.2

Переставить элементы массива так, чтобы поначалу размещались нули, затем положительные элементы в порядке возрастания, потом отрицательные элементы в порядке убывания.

Задать свой вопрос
1 ответ
// PascalABC.NET 3.0, сборка 1128
const
  nmax=100;
var
  n,i,j,nn,nz,np,t:integer;
  a,an,az,ap:array[1..nmax] of integer;
begin
  // формируем массив и выводим его
  Write('Количество элементов в массиве: '); Read(n);
  for i:=1 to n do begin
    a[i]:=Random(11)-5;
    Write(a[i],' ')
    end;
  Writeln;
  // разбиваем массив на три подмассива
  nn:=0; nz:=0; np:=0;
  for i:=1 to n do
    if a[i]lt;0 then begin nn:=nn+1; an[nn]:=a[i] end
    else
      if a[i]=0 then begin nz:=nz+1; az[nz]:=a[i] end
      else begin np:=np+1; ap[np]:=a[i] end;
  // сортируем массив с отрицательными элементами по убыванию
  for i:=1 to nn-1 do
    for j:=1 to nn-1 do
      if an[j]lt;an[j+1] then
        begin t:=an[j]; an[j]:=an[j+1]; an[j+1]:=t end;
  // сортируем массив с положительными элементами по возрастанию
  for i:=1 to np-1 do
    for j:=1 to np-1 do
      if ap[j]gt;ap[j+1] then
        begin t:=ap[j]; ap[j]:=ap[j+1]; ap[j+1]:=t end;
  // формируем новое содержимое массива a
  i:=0;
  for j:=1 to nz do begin i:=i+1; a[i]:=az[j] end;
  for j:=1 to np do begin i:=i+1; a[i]:=ap[j] end;
  for j:=1 to nn do begin i:=i+1; a[i]:=an[j] end;
  // вывод результата
  for i:=1 to n do Write(a[i],' ');
  Writeln
end.

Тестовое решение:
Количество элементов в массиве: 15
1 2 5 0 -5 -3 0 0 1 -4 3 -2 -2 0 -5
0 0 0 0 1 1 2 3 5 -2 -2 -3 -4 -5 -5
Гена Гасевкин
Если PascalABC, то можно еще так записать:  var i,j,n,m,k,tmp: integer;    a: array of integer;begin  write('n = ');  readln(n);  setlength(a,n);  randomize();  for i:=0 to n-1 do  begin    a[i]:=random(10)-5;    write(a[i]:3);  end;  writeln;  sort(a);  m:=0;  while a[m]<0 do inc(m);  k:=a.Length-1;  for i:=0 to m-1 do  begin    tmp:=a[0];    for j:=0 to k-i-1 do a[j]:=a[j+1];    a[k-i]:=tmp;  end;  for i:=0 to k do write(a[i]:3);end.       
Solomajkina Elizaveta
n = 20  3  0  2 -1 -2  4  0  3  1  3 -4  0  2  0 -5 -2 -4 -1  4 -4  0  0  0  0  1  2  2  3  3  3  4  4 -1 -1 -2 -2 -4 -4 -4 -5  - решение на испытательной задачке
, оставишь ответ?
Имя:*
E-Mail:


Добро пожаловать!

Для того чтобы стать полноценным пользователем нашего портала, вам необходимо пройти регистрацию.
Зарегистрироваться
Создайте собственную учетную запить!

Пройти регистрацию
Авторизоваться
Уже зарегистрированны? А ну-ка живо авторизуйтесь!

Войти на сайт