Форум программистов, компьютерный форум, киберфорум
Наши страницы
Turbo Pascal
Войти
Регистрация
Восстановить пароль
 
Polly_13
0 / 0 / 0
Регистрация: 27.04.2011
Сообщений: 7
1

Упорядочивание массива

27.04.2011, 13:18. Просмотров 414. Ответов 4
Метки нет (Все метки)

Прошу помочь с решением задачи:
Дан массив, заполненный случайными числами от 0 до 100. Размер массива задается пользователем. Требуется упорядочить массив по возрастанию суммы цифр каждого числа.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
27.04.2011, 13:18
Ответы с готовыми решениями:

Курсовая упорядочивание массива
Дан массив целых чисел Z=(z1,z2z3,...zn), n<=10. Найти произведение четных...

Упорядочивание элементов массива
Составить программу упорядочивания элементов массива К и расположить их в том...

Упорядочивание двумерного массива
Каким образом можно упорядочить по убыванию строки заданного двумерного...

Упорядочивание массива простым обменом
Пожалуйста, помогите решить задачу. Дан массив A размера N (<= 6). Упорядочить...

Упорядочивание одномерного массива по возростанию
описать процедуру упорядочивания одномерного массива по возростанию. составить...

4
Ksana_
92 / 46 / 22
Регистрация: 11.02.2010
Сообщений: 187
27.04.2011, 15:39 2
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
program Sort;
 
const N = 1000;
   var
    A: array[1..N] of integer;
    i, des, ed, buf, j, m: integer;
    f: boolean;
begin
  buf:= 0;
  repeat
  Writeln('Vvedite razmernost massiva do ', N);
  Readln(m);
  until m < N;
//Заполнение массива
  for i:= 1 to m do  begin
    A[i]:= random(100);
    Write(A[i], '  ');
    end;
  Writeln;
//Замена значений массива суммами их чисел
  for i:= 1 to m do  begin
    if A[i] > 9 then begin
      des:= A[i] div 10;
      ed:= A[i] mod 10;
      A[i]:= des + ed;
      end;
    end;
 
//Сортировка массива
  repeat f:= true ;
    for i:= 1 to m-1 do begin
      if A[i] > A[i+1] then begin
        buf:= A[i];
        A[i]:= A[i+1];
        A[i+1]:= buf;
        f:= false;
        end;
      end;
  until f = true;
 
  Writeln('Otsortirovanniy massiv');
  for i:= 1 to m do
    Writeln(A[i]);
  Readln;
end.
1
Polly_13
0 / 0 / 0
Регистрация: 27.04.2011
Сообщений: 7
27.04.2011, 17:06  [ТС] 3
Спасибо большое))
Вот только в итоге программа выдает сумму цифр элемента, а мне нужно, чтобы выводились исходные элементы массива, только в другом порядке. Что нужно подкорректировать?
0
Puporev
Модератор
54992 / 42295 / 29206
Регистрация: 18.05.2008
Сообщений: 99,928
27.04.2011, 17:11 4
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
program Sort;
function Summ(n:integer):byte;
var s:byte;
    m:integer;
begin
s:=0;
m:=n;
while m>0 do
 begin
  s:=s+m mod 10;
  m:=m div 10;
 end;
Summ:=s;
end;
const N = 1000;
   var
    A: array[1..N] of integer;
    i, des, ed, buf, j, m: integer;
    f: boolean;
begin
  buf:= 0;
  repeat
  Writeln('Vvedite razmernost massiva do ', N);
  Readln(m);
  until m < N;
//Заполнение массива
  for i:= 1 to m do  begin
    A[i]:= random(100);
    Write(A[i],' ');
    end;
  Writeln;
//Сортировка массива
  repeat
    f:= true ;
    for i:= 1 to m-1 do
    if Summ(A[i])>Summ(A[i+1]) then
      begin
        buf:= A[i];
        A[i]:= A[i+1];
        A[i+1]:= buf;
        f:= false;
       end;
  until f = true;
 
  Writeln('Otsortirovanniy massiv');
  for i:= 1 to m do
    Write(A[i],' ');
  Readln;
end.
1
Polly_13
0 / 0 / 0
Регистрация: 27.04.2011
Сообщений: 7
27.04.2011, 19:03  [ТС] 5
Благодарю, вы мне очень помогли
0
27.04.2011, 19:03
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
27.04.2011, 19:03

Смена мест элементов массива, упорядочивание
1. В массиве переставить местами 3 первых и 3 последних элемента, сохраняя их...

Смена мест элементов массива, упорядочивание
1. В массиве переставить местами 3 первых и 3 последних элемента, сохраняя их...

Упорядочивание элементов массива по возрастанию. Процедуры.
Задание 10. Создать программ с использованием процедур:Составить программу...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru