![]() |
Модераторы: bsa |
![]() ![]() ![]() |
|
Soeth |
|
|||
Новичок Профиль Группа: Участник Сообщений: 7 Регистрация: 30.6.2011 Репутация: нет Всего: нет |
Написал ф-ю сортировки массива методом Шейкера.
Собственно проблема в том, что программа впадает в бесконечный цикл после того, как весь массив отсортирован, L и R не пересекаются. Может подскажете в чём проблема? S,P - количество сравнений\ перестановок. N - длина массива. L - левая граница, R - правая. L1,R1 - индикаторы последней перестановки с левой\правой сторон.
|
|||
|
||||
feodorv |
|
|||
![]() Эксперт ![]() ![]() ![]() ![]() Профиль Группа: Комодератор Сообщений: 2214 Регистрация: 30.7.2011 Репутация: 12 Всего: 45 |
Ни фига не циклится:
Или дайте данные, на которых циклится... -------------------- Напильник, велосипед, грабли и костыли - основные инструменты программиста... |
|||
|
||||
Soeth |
|
|||
Новичок Профиль Группа: Участник Сообщений: 7 Регистрация: 30.6.2011 Репутация: нет Всего: нет |
Проверял на различных случайных массивах различных структур, но как пример:
В бесконечный цикл while входит при L = 3 и R = 4. |
|||
|
||||
feodorv |
|
|||
![]() Эксперт ![]() ![]() ![]() ![]() Профиль Группа: Комодератор Сообщений: 2214 Регистрация: 30.7.2011 Репутация: 12 Всего: 45 |
Не понятно, согласно какому описанию алгоритма Вы составили программу... На каждом шаге должны меняться либо L, либо R (иначе - зацикливание). При отсортированном списке обменов не происходит, и L и R так и остаются отличающимися на 1.
Как вариант решения:
Это сообщение отредактировал(а) feodorv - 16.2.2012, 02:45 -------------------- Напильник, велосипед, грабли и костыли - основные инструменты программиста... |
|||
|
||||
Soeth |
|
|||
Новичок Профиль Группа: Участник Сообщений: 7 Регистрация: 30.6.2011 Репутация: нет Всего: нет |
Составлял согласно тому, как препод в универе объяснял.
Благодарю за помощь, булеанская переменная поможет. ) |
|||
|
||||
![]() ![]() ![]() |
Правила форума "C/C++: Для новичков" | |
|
Запрещается! 1. Публиковать ссылки на вскрытые компоненты 2. Обсуждать взлом компонентов и делиться вскрытыми компонентами
Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, JackYF, bsa. |
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей) | |
0 Пользователей: | |
« Предыдущая тема | C/C++: Для новичков | Следующая тема » |
|
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности Powered by Invision Power Board(R) 1.3 © 2003 IPS, Inc. |