Аватар для DianKoV
0 / 0 / 0
Регистрация: 11.03.2017
Сообщений: 4

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

11.03.2017, 03:04. Показов 5520. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дан одномерный массив, который содержит не более 60 вещественных чисел, среди которых есть положительные, отрицательные и нули. Переставить элементы массива так, чтобы сначала шли нули, потом отрицательные, а затем положительные элементы массива.
В задаче использовать процедуры ввода и вывода элементов массива
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
11.03.2017, 03:04
Ответы с готовыми решениями:

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

Сформировать массив так, чтобы сначала шли отрицательные элементы, затем положительные и, наконец, нулевые
HELP! люди срочно требуется ваща помошь, по масивам! вот задача: Задан массив y из n целых чисел. Сформировать массив z так чтобы в...

Переставить элемента массива, так чтобы сначала было расположены все положительные элементы, потом все отрицательные
Всем добрый вечер! Есть задача: Кто знает как ее решить - помогите, с меня спасибо:)

2
Эксперт Pascal/Delphi
6812 / 4568 / 4820
Регистрация: 05.06.2014
Сообщений: 22,434
11.03.2017, 07:53
Найдено в интернете ((C) klem4) и чуть доработано
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
const
  n = 60;
 
var
  x: Array [1..n] of real;
  i, j, q: Integer;
  t: real;
 
begin
  randomize;
  for i := 1 to n do 
  begin
    x[i] := -n div 2 + random * n;
    write(x[i]:8:2);
  end;
  q := 1;
  while (q < n) and (x[q] = 0) do 
    inc(q);
  i := n;
  while (i > q) do 
  begin
    if x[i] = 0 then 
    begin
      inc(q);
      for j := i downto q do 
      begin
        T := x[j];
        x[j] := x[j - 1];
        x[j - 1] := T;
      end;
    end 
    else 
      dec(i);
  end;
  i := n;
  while (i > q) do 
  begin
    if x[i] < 0 then 
    begin
      inc(q);
      for j := i downto q do 
      begin
        T := x[j];
        x[j] := x[j - 1];
        x[j - 1] := T;
      end;
    end 
    else 
      dec(i);
  end;
  writeln;
  writeln('Преобразованный массив:');
  for i := 1 to n do 
    write(x[i]:8:2);
end.
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
11.03.2017, 08:51
Лучший ответ Сообщение было отмечено ZX Spectrum-128 как решение

Решение

ZX Spectrum-128,
следует заметить, что для именно этого задания решение избыточно, без внутренних циклов легко обойтись.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
const n=60;
var
  a: array [0..n+1] of Real;
  t: Real;
  p, q: Integer;
begin
  Randomize;
  for p:=1 to n do a[p]:=-100+200*Random;
  for p:=1 to n div 3 do a[1+Random(n)]:=0;
  WriteLn('A ='); for p:=1 to n do Write(a[p]:8:2); WriteLn;
  a[0]:=0; a[n+1]:=1;
  p:=1; q:=n;
  repeat
    while a[p]=0 do Inc(p);
    while a[q]<>0 do Dec(q);
    if p>=q then Break;
    t:=a[p]; a[p]:=a[q]; a[q]:=t; Dec(q);
  until False;
  q:=n;
  repeat
    while a[p]<0 do Inc(p);
    while a[q]>0 do Dec(q);
    if p>=q then Break;
    t:=a[p]; a[p]:=a[q]; a[q]:=t; Dec(q);
  until False;
  WriteLn('A''='); for p:=1 to n do Write(a[p]:8:2); WriteLn;
end.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.03.2017, 08:51
Помогаю со студенческими работами здесь

Разместить элементы массива так,чтоб сначала шли все положительные числа,а потом-отрицательные, не создавая новый массив
Дан массив из n целых чисел. Не используя новый массив, нужно разместить элементы массива так, чтобы сначала шли все положительные числа, а...

Переставить элементы массива так, чтобы сначала располагались все нули, затем единицы
Перестановка. В массиве X каждый элемент равен 0, 1 или 2. Переставить элементы массива так, чтобы сначала располагались все нули, затем...

Переставить числа в массиве так, чтобы сначала шли элементы меньшие b, затем равные b, а лишь затем большие b
Дан массив a и число b. Переставить числа в массиве так, чтобы сначала шли элементы меньшие b, затем равные b, а лишь затем большие b

Заполнить массив Y так, чтобы сначала располагались отрицательные, а затем положительные элементы массива X
Заполнить массив Y так, чтобы сначала располагались отрицательные, а затем положительные элементы массива X. Помогите, пожалуйста :)

Переставить элементы массива так, чтобы сначала располагались все нули, затем все единицы
В массиве А каждый элемент равен 0, 1, 2. Переставить элементы массива так, чтобы сначала располагались все нули, затем все единицы, и,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

Новые блоги и статьи
сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и источниками (напряжения, ЭДС и тока). Найти токи и напряжения во всех элементах. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru