Быстрая сортировка (QSort) (реализация на C++)

C++   23 Март 2012  Автор статьи:  

В данной статье я представлю рекурсивный пример реализации быстрой сортировки. Массив, который нужно отсортировать будет глобальным, если же вы захотите сделать его локальным, то просто передавайте его как параметр в функцию.Конечно, после того, как вы сделаете это вам нужно будет использовать template для того, чтобы ваша функция работала со всеми типами данных. Я этим заниматься в рамках данной статьи не буду, поэтому просто приведу код рекурсивной сортировки quicksort:

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
#include <iostream>
using namespace std;
int a[100];
void quickSort(int l, int r)
{
    int x = a[l + (r - l) / 2];
    //запись эквивалентна (l+r)/2,
    //но не вызввает переполнения на больших данных
    int i = l;
    int j = r;
    //код в while обычно выносят в процедуру particle
    while(i <= j)
    {
        while(a[i] < x) i++;
        while(a[j] > x) j--;
        if(i <= j)
        {
            swap(a[i], a[j]);
            i++;
            j--;
        }
    }
    if (i<r)
                quickSort(i, r);
   
    if (l<j)   
        quickSort(l, j);    
}
int main()
{
    int n;//количество элементов в массиве
    cin >> n;
    for(int i = 0; i < n; i++)
    {
        cin>>a[i];
    }
    quickSort(0, n-1);
    for(int i = 0; i < n; i++)
    {
        cout<<a[i]<<" ";
    }        
    return 0;
}

  • Петро Мельник

    cпс

  • Alex

    Замечательно

  • Alex

    Замечательно

  • Денис

    Я этим заниматься в рамках данной статьи не буду

    А где статья-то? Только короткий листинг, и тот приведен без объяснения алгоритма. И почему делать нужно функцию шаблоннной при переносе массива из глобального скопа в скоп функции?

  • Хорин Алексей

    Не красиво делать массив глобальным!

    • http://cybern.ru/ lordrp

      В алгоритме это не важно.

  • Alt

    if (i<r)

    qsort(i, r);

    if (l<j)

    qsort(l, j);

    для чего эти два ифа?

    • http://cybern.ru/ lordrp

      Посмотрите теорию алгоритма, в этих ифах вся соль.

Научиться программировать

  • на Delphi

  • на Java

  • на C++