Консультация # 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);
}
Во-вторых, да, функция разделения возвращает индекс, относительно которого массив разбивается на две части, в первой из которых сосредоточены меньшие значения, а во второй – большие. Другими словами, "индекс опорного элемента, который является медианой массива" Медиана - это элемент, разделяющий массив на меньшие (слева) и большие (справа) значения. Откуда Вы взяли термин "среднеарифметическое"?
Команда портала RFPRO.RU благодарит Вас за то, что Вы пользуетесь нашими услугами. Вы только что прочли очередной выпуск рассылки. Мы старались.
Пожалуйста, оцените его. Если совет помог Вам, если Вам понравился ответ, Вы можете поблагодарить автора -
для этого в каждом ответе есть специальные ссылки. Вы можете оставить отзыв о работе портале. Нам очень важно знать Ваше мнение.
Вы можете поближе познакомиться с жизнью портала, посетив наш форум, почитав журнал,
который издают наши эксперты. Если у Вас есть желание помочь людям, поделиться своими знаниями, Вы можете зарегистрироваться экспертом.
Заходите - у нас интересно!