Модераторы: bsa
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Сортировка массива. 
:(
    Опции темы
Soeth
Дата 15.2.2012, 17:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 7
Регистрация: 30.6.2011

Репутация: нет
Всего: нет



Написал ф-ю сортировки массива методом Шейкера.
Собственно проблема в том, что программа впадает в бесконечный цикл после того, как весь массив отсортирован, L и R не пересекаются.
Может подскажете в чём проблема?
S,P - количество сравнений\ перестановок.
N - длина массива.
L - левая граница, R - правая.
L1,R1 - индикаторы последней перестановки с левой\правой сторон.
Код

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;
}  

PM MAIL   Вверх
feodorv
Дата 15.2.2012, 18:44 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2214
Регистрация: 30.7.2011

Репутация: 12
Всего: 45



Цитата(Soeth @  15.2.2012,  17:37 Найти цитируемый пост)
программа впадает в бесконечный цикл

Ни фига не циклится:
Код

#include <stdio.h>

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)++;
            printf( "L=%d\n", L);
            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)++;
            printf( "R=%d\n", R);
            if(arr[R] < arr[R - 1]){
                buff = arr[R];
                arr[R] = arr[R - 1];
                arr[R - 1] = buff;
                R1 = R;
                (*P)++;
            }
        }
        R = L1;
        printf( "L=%d R=%d\n", L, R);
    }
    return 0;
}

int main( void )
{
  int i;
  int m[201];
  int S, P;

  S = P = 0;
  for( i = 0; i < 201; i++) m[i] = 100-i;
  SheikerSort( m, 201, &S, &P);
  printf( "S = %d, P = %d\n", S, P);

  S = P = 0;
  for( i = 0; i < 201; i++) m[i] = 100-i%2;
  SheikerSort( m, 201, &S, &P);
  printf( "S = %d, P = %d\n", S, P);

  return 0;
}

Или дайте данные, на которых циклится...


--------------------
Напильник, велосипед, грабли и костыли - основные инструменты программиста...
PM MAIL   Вверх
Soeth
Дата 15.2.2012, 21:01 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 7
Регистрация: 30.6.2011

Репутация: нет
Всего: нет



Проверял на различных случайных массивах различных структур, но как пример:

Код

int main()
{
    int arr[8] = {44, 55, 12, 42, 94, 18, 06, 67};
    int N = 8, S = 0, P = 0;
    SheikerSort(arr,N,S,P);

        cout << "Comparisons: " << S << endl;
        cout << "Permutations: " << P << endl;

    for (int i=0; i <= N-1; i++){
        cout << arr[i] << endl;
    }

    system("pause");

}

В бесконечный цикл while входит при L = 3 и R = 4.
PM MAIL   Вверх
feodorv
Дата 16.2.2012, 02:42 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Комодератор
Сообщений: 2214
Регистрация: 30.7.2011

Репутация: 12
Всего: 45



Не понятно, согласно какому описанию алгоритма Вы составили программу... На каждом шаге должны меняться либо L, либо R (иначе - зацикливание). При отсортированном списке обменов не происходит, и L и R так и остаются отличающимися на 1.

Как вариант решения:
Цитата
вводится достаточное прерывание проходов, если на очередном проходе обнаруживается, что нет ни одного обмена.
 Цитата взята отсюда.


Это сообщение отредактировал(а) feodorv - 16.2.2012, 02:45


--------------------
Напильник, велосипед, грабли и костыли - основные инструменты программиста...
PM MAIL   Вверх
Soeth
Дата 16.2.2012, 10:08 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Новичок



Профиль
Группа: Участник
Сообщений: 7
Регистрация: 30.6.2011

Репутация: нет
Всего: нет



Составлял согласно тому, как препод в универе объяснял.
Благодарю за помощь, булеанская переменная поможет. )
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "C/C++: Для новичков"
JackYF
bsa

Запрещается!

1. Публиковать ссылки на вскрытые компоненты

2. Обсуждать взлом компонентов и делиться вскрытыми компонентами

  • Действия модераторов можно обсудить здесь
  • С просьбами о написании курсовой, реферата и т.п. обращаться сюда
  • Вопросы по реализации алгоритмов рассматриваются здесь


Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, JackYF, bsa.

 
0 Пользователей читают эту тему (0 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Для новичков | Следующая тема »


 




[ Время генерации скрипта: 0.0661 ]   [ Использовано запросов: 22 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.