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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
strag 93
1 / 1 / 0
Регистрация: 14.11.2010
Сообщений: 57
#1

Динамический массив отсортировать по возростанию методом быстрой сортировки - C++

14.05.2012, 19:39. Просмотров 653. Ответов 1
Метки нет (Все метки)

Отсортировать дин. масив по возростанию методом быстрой сортировки.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.05.2012, 19:39     Динамический массив отсортировать по возростанию методом быстрой сортировки
Посмотрите здесь:

Заполнить случайныйми числами одномерный динамический массив; отсортировать его методом пузырьковой сортировки - C++
В плюсах полный ноль...помогите пожалуйста создать одномерный массив через new и delete его сортировку пузырьком и вывод. Заранее спасибо.

Отсортировать методом быстрой сортировки элементы массива, стоящие на четных позициях - C++
Имеется одномерный массив длиной N = 50. Отсортировать методом быстрой сортировки элементы массива, стоящие на четных позициях, так, чтобы...

Отсортировать все строки методом быстрой сортировки так, чтоб элементы в них располагались по возрастанию - C++
Всем привет:) Не могу никак сделать, помогите, кто шарит) Есть массив 10 на 10. Нужно отсортировать все строки методом быстрой...

Отсортировать массив с помощью сортировки методом вставки - C++
Подскажите код,есть такая задачка...Дан двумерный массив заполненый с помощью генератора случайных чисел, отсортировать массив с помощью...

Создать динамический целочисленный массив, и отсортировать его методом вставок - C++
Помогите пожалуйста создать динамический целочисленный массив. Размер массива вводится с клавиатуры. Массив заполняется случайными числами,...

Сортировка последовательности методом быстрой сортировки - C++
помогите :Написати програму для сортування послідовності 45 37 2 5 9 12 6 4 52 методом швидкого сортування. На кожному кроці виводити...

Сортировка координат (методом быстрой сортировки) - C++
Как отсортировать координаты сначала по x, а при равных x по y, методом быстрой сортировки? Если отсортировать по x, а затем по y, можем...

отсортировать массив по возростанию - C++
Есть массив, в последней колонке есть количество простых чисел в строке. нужно отсортировать строки массива по кол простых чисел в строке...

Комбинированный метод быстрой сортировки с методом «пузырька» - C++
Выполнить сортировку целочисленного массива (поиск в массиве) из n элементов. Алгоритм сортировки (поиска) оформить в виде функции. ...

Отсортировать масив методом пузырьковой сортировки - C++
1). Создать 2 массива по 5 элементов. Заполнить их случайными числами и отсортировать первый в возрастающем порядке, а второй в убывающем. ...

Написать функцию, которая сортирует переданный ей динамический массив "быстрой" сортировкой - C++
#include <iostream> #include <vector> using namespace std; void qSort( vector <int> &A,int nStart, int nEnd) { int...

Отсортировать массив методом минимального элемента и методом пузырька - C++
Друзья помогите! Очень мало времени на поиски подобного на сайте... А (100) -Случайные числа. Отсортировать массив методом минимального...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Toshkarik
1139 / 856 / 51
Регистрация: 03.08.2011
Сообщений: 2,384
Завершенные тесты: 1
15.05.2012, 09:45     Динамический массив отсортировать по возростанию методом быстрой сортировки #2
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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#include <iostream>
#include <cstdlib>
#include <ctime>
 
template< typename T >
void quickSort( T *array, const std::size_t size ) {
   T temp;
   
   std::size_t leftBorderStack[ 32 ] = { 0 },
               rightBorderStack[ 32 ] = { 0, size - 1 },
               stackPos = 1,
               leftBorder = 0,
               rightBorder = 0,
               leftPartSize = 0,
               rightPartSize = 0,
               left = 0,
               right = 0,
               pivotElement = 0;
 
 
   while ( stackPos > 0 ) {
      leftBorder = leftBorderStack[ stackPos ];
      rightBorder = rightBorderStack[ stackPos ];
      stackPos--;
 
      while ( leftBorder < rightBorder ) {
         left = leftBorder;
         right = rightBorder;
         pivotElement = leftBorder;
 
         while ( left < right ) {
            while ( pivotElement < right )
               if ( array[ pivotElement ] > array[ right ] ) {
                  temp = array[ pivotElement ];
                  array[ pivotElement ] = array[ right ];
                  array[ right ] = temp;
                  left = pivotElement + 1;
                  pivotElement = right;
               } else
                  right--;
 
            while ( pivotElement > left )
               if ( array[ pivotElement ] < array[ left ] ) {
                  temp = array[ pivotElement ];
                  array[ pivotElement ] = array[ left ];
                  array[ left ] = temp;
                  right = pivotElement - 1;
                  pivotElement = left;
               } else
                  left++;
         }
 
         rightPartSize = rightBorder - pivotElement;
         leftPartSize = pivotElement - leftBorder;
 
         if ( rightPartSize > leftPartSize ) {
            if ( rightPartSize > 1 ) {
               stackPos++;
               leftBorderStack[ stackPos ] = pivotElement + 1;
               rightBorderStack[ stackPos ] = rightBorder;
            }
            
            rightBorder = pivotElement;
         } else {
            if ( leftPartSize > 1 ) {
               stackPos++;
               leftBorderStack[ stackPos ] = leftBorder;
               rightBorderStack[ stackPos ] = pivotElement - 1;
            }
            
            leftBorder = pivotElement;
         }
      }
   }
}
 
int main() {
   std::size_t size = 200;
   int *array = new int [ size ];
   
   std::srand( std::time( 0 ));
   
   for ( std::size_t i = 0; i < size; i++ ) {
      array[ i ] = std::rand() % 100;
      
      std::cout << array[ i ] << ' ';
   }
   
   std::cout << '\n' << std::endl;
      
   quickSort( array, size );
   
   for ( std::size_t i = 0; i < size; i++ )
      std::cout << array[ i ] << ' ';
      
   std::cout << std::endl;
   
   return 0;
}
Yandex
Объявления
15.05.2012, 09:45     Динамический массив отсортировать по возростанию методом быстрой сортировки
Ответ Создать тему
Опции темы

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