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

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

Войти
Регистрация
Восстановить пароль
 
BassRefleXive
Сообщений: n/a
#1

Сортировка массива. - C++

15.02.2012, 18:33. Просмотров 286. Ответов 0
Метки нет (Все метки)

Написал ф-ю сортировки массива методом Шейкера.
Собственно проблема в том, что программа впадает в бесконечный цикл после того, как весь массив отсортирован, L и R не пересекаются.
Может подскажете в чём проблема?
S,P - количество сравнений\ перестановок.
N - длина массива.
L - левая граница, R - правая.
L1,R1 - индикаторы последней перестановки с левой\правой сторон.
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
int SheikerSort(int arr[], int N, int &S, int &P)
{
    int L = 0, R = N - 1,L1 = 0, R1 = 0, buff;
    while(R != L){
        for(L = R1; L <= R - 1; L++){
            S++;
            if(arr[L] > arr[L + 1]){
                buff = arr[L];
                arr[L] = arr[L + 1];
                arr[L + 1] = buff;
                L1 = L;
                P++;
            }
        }
        L = R1;
        for(R = L1; R >= L + 1; R--){
            S++;
            if(arr[R] < arr[R - 1]){
                buff = arr[R];
                arr[R] = arr[R - 1];
                arr[R - 1] = buff;
                R1 = R;
                P++;
            }
        }
        R = L1;
    }
    return 0;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.02.2012, 18:33     Сортировка массива.
Посмотрите здесь:

Сортировка массива структур через сортировку массива указателей - C++
Ошибка возникает в функции void sort(student **ppStud, int k, char ch). Кто видит ошибку - помогите, пожалуйста. Код программы: ...

Сортировка массива O(m+n) - C++
Добрые программисты. Объясните, пожалуйста, как можно решить задачу с сортировкой. Можно подробно не расписывать (без кода), укажите...

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

Сортировка массива - C++
Нужно пересортировать массив 0 0 0 0 0 0 0 1 2 0 3 2 0 0 0 0 0 0 0 2 4 0 6 7 0 3 5 0 7 6 в массив

сортировка массива - C++
нужно найти ошибку..у меня не получается( // efficient_sort.cpp: определяет точку входа для консольного приложения. // #include...

Сортировка массива - C++
Помогите пожалуйста с конечным результатом #include &lt;iostream&gt; #include &lt;string&gt; #include &lt;locale&gt; #include &lt;windows.h&gt; #include...

Сортировка массива - C++
Помогите, пожалуйста, не могу отсортировать символы с помощью таблицы ANSI #include &lt;iostream&gt; using namespace std; void...

Сортировка массива - C++
Здравствуйте. Посмотрите пожалуйста, в чем ошибка!! В С++ Билдере у меня работала такая функция для сортировки: int* Insert (int*...

Сортировка массива - C++
Задается размер массива N и затем с клавиатуры вводится вещественный массив заданного размера. Отсортировать по возрастанию элементы...

Сортировка массива - C++
#include &lt;iostream&gt; #include &lt;conio.h&gt; #include &lt;cstdlib&gt; using namespace std; int main() { int...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

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