Форум программистов, компьютерный форум CyberForum.ru

Отсортировать по возрастанию элементы массива - C++

Восстановить пароль Регистрация
 
мутя
6 / 6 / 1
Регистрация: 30.03.2011
Сообщений: 12
31.03.2011, 01:01     Отсортировать по возрастанию элементы массива #1
В массиве А [1 .. n] каждый элемент изменяется в пределах от 0 .. 20. Отсортировать по возрастанию.
C++
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
31.03.2011, 01:01     Отсортировать по возрастанию элементы массива
Посмотрите здесь:

C++ Отсортировать элементы массива по возрастанию с сохранением позиций нулей
C++ Отсортировать по возрастанию элементы массива
C++ Отсортировать по возрастанию отрицательные элементы массива методом выбора
Отсортировать элементы массива по возрастанию методом обмена C++
C++ Отсортировать элементы массива по возрастанию
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
HighPredator
 Аватар для HighPredator
5350 / 1733 / 320
Регистрация: 10.12.2010
Сообщений: 5,120
Записей в блоге: 3
31.03.2011, 01:04     Отсортировать по возрастанию элементы массива #2
В следующий раз пользуйтесь поиском. Алгоритмы сортировок
taras atavin
Ушёл с форума.
 Аватар для taras atavin
3569 / 1752 / 91
Регистрация: 24.11.2009
Сообщений: 27,619
31.03.2011, 08:14     Отсортировать по возрастанию элементы массива #3
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
void Sort(int *a, int n)
{
 int *i, *j, *e=a+n-1;
 int t;
 for (i=e; i>a; --i)
 {
  for (j=i-1; j>=a; --j)
  {
   if (*i<*j)
   {
    t=*i;
    *i=*j;
    *j=t;
   }
  }
 }
}
Добавлено через 53 секунды
И сёвые массивы индексируются с ноля.
мутя
6 / 6 / 1
Регистрация: 30.03.2011
Сообщений: 12
05.06.2011, 19:09  [ТС]     Отсортировать по возрастанию элементы массива #4
Сообщение было отмечено автором темы, экспертом или модератором как ответ
Я все понял. Спасибо

Добавлено через 1 минуту
C
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
#include "stdafx.h"
#include "stdio.h"
#include "stdlib.h"
#include "locale.h"
#include "time.h"
 
void QuickSort (int *mas, int n);
void main()
{
int nums[300],k;
setlocale(LC_ALL,"Russian");
srand(time(NULL));
printf("Введiть довжину масиву:");
scanf("%d",&k);
for (int i=0; i<k; i++)
{
nums[i]=rand()%20;
}
printf("Заданий масив:\n");
for (int i=0; i<k; i++)
printf("%5d",nums[i]);
printf("\nСортування:\n");
QuickSort (nums,k);
for (int i=0; i<k; i++)
printf("%5d",nums[i]);
printf("\n");
 
}
 
void QuickSort (int *mas, int n)
{
int i=0,j=n-1;
int p,tmp;
p=*(mas+n/2);
do
{
while (*(mas+i)<p) i++;
while (*(mas+j)>p) j--;
if(i<=j)
{
tmp=mas[i];
mas[i]=mas[j];
mas[j]=tmp;
i++; j--;
}
}
while (i<=j);
if(j>0) QuickSort(mas,i);
if(n>i) QuickSort(mas+i,n-i);
}
Yandex
Объявления
05.06.2011, 19:09     Отсортировать по возрастанию элементы массива
Ответ Создать тему
Опции темы

Текущее время: 12:21. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru