在线编译器 C

#include <stdio.h> void quicksort(int arr[], int left, int right) { if (left >= right) return; int pivot = arr[(left + right) / 2]; int i = left, j = right; while (i <= j) { while (arr[i] < pivot) i++; while (arr[j] > pivot) j--; if (i <= j) { int temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; i++; j--; } } quicksort(arr, left, j); quicksort(arr, i, right); } int main() { int arr[] = {5, 2, 0, 1, 5, 6}; int n = sizeof(arr) / sizeof(arr[0]); quicksort(arr, 0, n - 1); for (int i = 0; i < n; i++) { printf("%d ", arr[i]); } return 0; }
1) Этот код реализует алгоритм быстрой сортировки (quicksort) для сортировки массива целых чисел по возрастанию и выводит отсортированный результат.

2) Подсказки:
- Обрати внимание на условие завершения рекурсии в функции `quicksort` — оно проверяет, что левая граница не превышает правую.
- Убедись, что понимаешь, как выбирается опорный элемент (pivot) и как указатели `i` и `j` перемещаются по массиву, сравнивая элементы с pivot.