Отправляет email-рассылки с помощью сервиса Sendsay
  Все выпуски  

RFpro.ru: Программирование на C / C++


РАССЫЛКИ ПОРТАЛА RFPRO.RU

Лучшие эксперты в разделе

Коцюрбенко Алексей aka Жерар
Статус: Мастер-Эксперт
Рейтинг: 373
∙ повысить рейтинг »
Степанов Иван /REDDS
Статус: 3-й класс
Рейтинг: 137
∙ повысить рейтинг »
solowey
Статус: 3-й класс
Рейтинг: 110
∙ повысить рейтинг »

∙ С / С++

Номер выпуска:1893
Дата выхода:12.12.2016, 10:45
Администратор рассылки:Андрей Кузнецов aka Dr_Andrew (Старший модератор)
Подписчиков / экспертов:23 / 16
Вопросов / ответов:1 / 1

Консультация # 190243: Здравствуйте! У меня возникли трудности с быстрой сортировкой. Не совсем понимаю, что возвращает функция разделения. Индекс опорного элемента, который является медианой массива? Медиана это когда среднеарифметическое слева от нее [медианы] меньше этого элемента, а справа - больше? Или среднеарифметические сравниваются не с элементом, а друг с...

Консультация # 190243:

Здравствуйте! У меня возникли трудности с быстрой сортировкой.
Не совсем понимаю, что возвращает функция разделения. Индекс опорного элемента, который является медианой массива?
Медиана это когда среднеарифметическое слева от нее [медианы] меньше этого элемента, а справа - больше? Или среднеарифметические сравниваются не с элементом, а друг с другом?

int partHoare (int a[], int p, int r) {
    int x=a[p],i=p-1,j=r;
    while (1)
    {
        do  j--; while (a[j] > x);
        do  i++; while (a[i] < x);
        if  (i < j)   // надо ли после этого ещё сравнивать a[i]>a[j]?
            swap(&a[i], &a[j]);
        else 
            return j+1;
    }
}
void QuickSort (int a[], int start, int end) {
    int q;
    if (end-start<2) return;
    q = partHoare (a, start, end);
    QuickSort (a, start, q);
    QuickSort (a, q, end);
}


Дата отправки: 07.12.2016, 10:40
Вопрос задал: АнтонНР (Посетитель)
Всего ответов: 1
Страница онлайн-консультации »


Консультирует Лысков Игорь Витальевич (Старший модератор):

Здравствуйте, АнтонНР!
Во-первых, была ошибка в разбиении массива (ф-я partHoare). Должно быть:

       while (a[j] > x) j--;
       while (a[i] < x) i++;

Во-вторых, да, функция разделения возвращает индекс, относительно которого массив разбивается на две части,
в первой из которых сосредоточены меньшие значения, а во второй – большие.
Другими словами, "индекс опорного элемента, который является медианой массива"
Медиана - это элемент, разделяющий массив на меньшие (слева) и большие (справа) значения.
Откуда Вы взяли термин "среднеарифметическое"? smile
void swap(int* i1, int* i2)
{
	*i1 ^= *i2;
	*i2 ^= *i1;
	*i1 ^= *i2;
}

int partHoare (int a[], int p, int r) {
    int x=a[p],i=p-1,j=r;
    while (1)
    {
        while (a[j] > x) j--;
        while (a[i] < x) i++;
        if  (i < j)
            swap(&a[i], &a[j]);
        else 
            return j+1;
    }
}
void QuickSort (int a[], int start, int end) {
    int q;
    if (end-start<2) return;
    q = partHoare (a, start, end);
    QuickSort (a, start, q);
    QuickSort (a, q, end);
}

int main(int argc, char* argv[])
{
	int	a[8] = {9,6,3,4,10,8,2,7} ;

	QuickSort(a, 0, 7) ;

	return 0;
}

Консультировал: Лысков Игорь Витальевич (Старший модератор)
Дата отправки: 07.12.2016, 14:29
Рейтинг ответа:

НЕ одобряю 0 одобряю!


Оценить выпуск | Задать вопрос экспертам

главная страница  |  стать участником  |  получить консультацию
техническая поддержка

Дорогой читатель!
Команда портала RFPRO.RU благодарит Вас за то, что Вы пользуетесь нашими услугами. Вы только что прочли очередной выпуск рассылки. Мы старались. Пожалуйста, оцените его. Если совет помог Вам, если Вам понравился ответ, Вы можете поблагодарить автора - для этого в каждом ответе есть специальные ссылки. Вы можете оставить отзыв о работе портале. Нам очень важно знать Ваше мнение. Вы можете поближе познакомиться с жизнью портала, посетив наш форум, почитав журнал, который издают наши эксперты. Если у Вас есть желание помочь людям, поделиться своими знаниями, Вы можете зарегистрироваться экспертом. Заходите - у нас интересно!
МЫ РАБОТАЕМ ДЛЯ ВАС!


В избранное