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

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

Войти
Регистрация
Восстановить пароль
 
 
Рейтинг: Рейтинг темы: голосов - 16, средняя оценка - 4.63
mmd
13 / 13 / 1
Регистрация: 17.05.2012
Сообщений: 80
#1

Алгоритм сортировки - C++

17.05.2012, 08:44. Просмотров 2085. Ответов 21
Метки нет (Все метки)

пацаны ребята помогите, реализовал два алгоритма на C++, алгоритм сортировки пирамидальный(кучей) и быстрой сортировки, все они сортируют массив в любом случае, но иногда например ввожу последовательность 2 1 3 45 12 5 23 6 4 89 2 он ее сортирует так: 0 1 2 2 3 4 5 12 23 45 и все и не дописывает в конце последний элемент, если на выходи когда массив уже отсортирован в цикле когда его отображаю, число итераций увеличить на единицу т е итераций больше чем размер массива, то тогда все получается и он дописывает недостающий символ в конце, но нуль остается в самом начале. вопрос, почему появляется нуль и как от него избавиться? спасибо

вот код:

быстрая сортировка:

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
#include <iostream>
using namespace std;
 
void qicksort(int *a, int p, int r);
int partition(int *a, int p, int r);
 
int main(int argc, char *argv[])
{
 
    int *a;
    int size;
 
    cin >> size;
 
    a=new int (size);
 
    for(int i=0; i<size; i++)
    {
        cin >> a[i];
    }
 
    qicksort(a,0,size);
 
    for(int i=0; i<size; i++)
    {
        cout << a[i] << " ";
    }
 
    return 0;
}
 
void qicksort(int *a, int p, int r)
{
 
    int q;
 
    if(p<r)
    {
        q=partition(a,p,r);
        qicksort(a,p,q-1);
        qicksort(a,q+1,r);
    }
 
}
 
int partition(int *a, int p, int r)
{
 
    int t,k,x,i;
 
    x=a[r];
    i=p-1;
 
    for(int j=p; j<=(r-1); j++)
    {
        if(a[j]<=x)
        {
            i++;
            t=a[i];
            a[i]=a[j];
            a[j]=t;
        }
    }
 
    k=a[i+1];
    a[i+1]=a[r];
    a[r]=k;
 
    return (i+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
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
100
101
102
103
104
105
106
107
108
109
110
#include <iostream>
using namespace std;
 
void max_heapify(int *a, int i, int size);
void build_max_heap(int *a, int i, int size);
void heapsort(int *a, int i, int size);
int parent(int i);
int left(int i);
int right(int i);
 
int main(int argc, char *argv[])
{
    int *a;
    int size,i;
 
    cin >> size;
 
    i=0;
 
    a=new int(size);
 
    for(int i=0; i<size; i++)
    {
        cin >> a[i];
    }
 
    heapsort(a,i,size);
 
    for(i=0; i<size; i++)
    {
        cout << a[i] << " ";
    }
 
    delete [] a;
 
    return 0;
}
 
int parent(int i)
{
    return (i/2);
}
 
int left(int i)
{
    return (2*i);
}
 
int right(int i)
{
    return ((2*i)+1);
}
 
void max_heapify(int *a, int i, int size)
{
    int l,r;
    int largest;
    int t=0;
 
    l=left(i);
    r=right(i);
 
    if((l<=size) && (a[l]>a[i]))
    {
        largest=l;
    }
    else
    {
        largest=i;
    }
 
    if((r<=size) && (a[r]>a[largest]))
    {
        largest=r;
    }
 
    if(largest!=i)
    {
        t=a[i];
        a[i]=a[largest];
        a[largest]=t;
        max_heapify(a,largest,size);
    }
}
 
void build_max_heap(int *a, int i, int size)
{
    i=size;
 
    for(int i=(size/2); i>=0; i--)
    {
        max_heapify(a,i,size);
    }
}
 
void heapsort(int *a, int i, int size)
{
    int t=0;
 
    build_max_heap(a,i,size);
 
    for(int i=size; i>=1; i--)
    {
        t=a[0];
        a[0]=a[i];
        a[i]=t;
        size=size-1;
        max_heapify(a,0,size);
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.05.2012, 08:44
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Алгоритм сортировки (C++):

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

Алгоритм сортировки - C++
учитель попросил написать сортировку массива по возрастанию в общем виде #include &lt;stdio.h&gt; #include &lt;string.h&gt; int main() { ...

Алгоритм сортировки - C++
Здравствуйте, подскажите пожалуйста какой алгоритм можно использовать при решении такой задачи: Дана строка char * из букв и цифр...

Алгоритм квадратичной сортировки - C++
Доброго времени суток! есть вот такая задача: При составлении программы сортировки использовать минимальную необходимую память и...

Алгоритм пузырьковой сортировки - C++
#include&lt;iostream.h&gt; #define SIZE 5 void bsort (int iArray, int n); int main() { char ch; int ii; int iArray ; for(ii =...

Алгоритм сортировки вставками - C++
Привет, всем! В алгоритме непонятна одна строчка: #include&lt;iostream&gt; #include&lt;cstdlib&gt; using namespace std; int...

21
MrGluck
Модератор
Эксперт CЭксперт С++
7278 / 4439 / 650
Регистрация: 29.11.2010
Сообщений: 12,019
17.05.2012, 17:35 #16
Цитата Сообщение от mmd Посмотреть сообщение
ппц я это знаю, что дальше то!? я так понял никто не может ответить на вопрос
элемента arr[N] не существует, т.к. индексация начинается с 0, а вы к нему обращаетесь
0
mmd
13 / 13 / 1
Регистрация: 17.05.2012
Сообщений: 80
17.05.2012, 17:50  [ТС] #17
Цитата Сообщение от MrGluck Посмотреть сообщение
элемента arr[N] не существует, т.к. индексация начинается с 0, а вы к нему обращаетесь
да ничего не помогает все равно
0
valeriikozlov
Эксперт С++
4670 / 2496 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
17.05.2012, 18:12 #18
посмотрел только первую сортировку (и даже не до конца) (см. коментарии):
Например size равно 10. Индексы максива a[] в диапазоне 0..9 (т.е. можно так: a[0] или так a[9], но нельзя a[10] или a[-1]). Больше или меньше индексы - выход за границы массива.
Цитата Сообщение от mmd Посмотреть сообщение
qicksort(a,0,size);//Здесь size равно 10 (для нашего случая)
Цитата Сообщение от mmd Посмотреть сообщение
void qicksort(int *a, int p, int r)// здесь r равно 10
{
int q;
if(p<r)
{
q=partition(a,p,r);// здесь r равно 10
Цитата Сообщение от mmd Посмотреть сообщение
int partition(int *a, int p, int r)// здесь r равно 10
{
int t,k,x,i;
x=a[r];// а вот здесь обращаемся к несуществующему элементу массива (выход за границы массива)
1
MrGluck
Модератор
Эксперт CЭксперт С++
7278 / 4439 / 650
Регистрация: 29.11.2010
Сообщений: 12,019
17.05.2012, 18:17 #19
Цитата Сообщение от valeriikozlov Посмотреть сообщение
посмотрел только первую сортировку (и даже не до конца) (см. коментарии):
Например size равно 10. Индексы максива a[] в диапазоне 0..9 (т.е. можно так: a[0] или так a[9], но нельзя a[10] или a[-1]). Больше или меньше индексы - выход за границы массива.
я ему еще в прошлой теме это объяснял по несколько раз, его ответ - "И чё?"

P.S. не стоит дублировать темы Алгоритм сортировки
0
mmd
13 / 13 / 1
Регистрация: 17.05.2012
Сообщений: 80
17.05.2012, 22:13  [ТС] #20
все заработало
спасибочки всем
0
Ternsip
660 / 188 / 6
Регистрация: 10.05.2012
Сообщений: 595
18.05.2012, 12:05 #21
mmd, Разберите мой алгоритм, который на delphi, если не получается, то напишите...В таком случае я попробую разобрать ваш алгоритм, но доказать правильность алгоритма довольно сложно, особенно если это Qsort 3
0
mmd
13 / 13 / 1
Регистрация: 17.05.2012
Сообщений: 80
18.05.2012, 18:59  [ТС] #22
Цитата Сообщение от Ternsip Посмотреть сообщение
mmd, Разберите мой алгоритм, который на delphi, если не получается, то напишите...В таком случае я попробую разобрать ваш алгоритм, но доказать правильность алгоритма довольно сложно, особенно если это Qsort 3
я уже разобрался в чем ошибка
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.05.2012, 18:59
Привет! Вот еще темы с ответами:

Неизвестный алгоритм сортировки - C++
Доброго времени суток! Возможно вопрос данный выглядит весьма по-дурацки, но тем не менее. Предыстория такова. Некоторое время назад...

Алгоритм сортировки в файле - C++
Никак не могу придумать как отсортировать массив значений. Есть файл, в котором находятся данные типа (вершины прямоугольник) : 20 20 69...

Алгоритм сортировки Шелла - C++
http://lord-n.narod.ru/download/books/walla/programming/Spr_po_C/21/2107.htm здесь сказано, что существует, некая последовательность...

Реализовать алгоритм сортировки - C++
На рисунке расположены, все возможные компоненты имеющие свойства x,y. Размер рабочей части 8x8, но может быть и больше. Задача такая:...


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

Или воспользуйтесь поиском по форуму:
22
Yandex
Объявления
18.05.2012, 18:59
Ответ Создать тему
Опции темы

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