Сортировка массива в C: алгоритмы и примеры кода

В C существует несколько способов сортировки массива. Вот некоторые из них:

1. Сортировка пузырьком (Bubble Sort):

Этот метод проходит по массиву несколько раз, сравнивая каждый элемент соседних пар и меняя их местами, если они стоят не в нужном порядке. Процесс продолжается до тех пор, пока весь массив не будет отсортирован. Вот пример кода:

c
void bubbleSort(int arr[], int n) {
    for (int i = 0; i < n - 1; i++) {
        for (int j = 0; j < n - i - 1; j++) {
            if (arr[j] > arr[j + 1]) {
                // меняем местами элементы
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

2. Сортировка выбором (Selection Sort):

В этом методе происходит поиск наименьшего элемента в массиве и помещение его на первую позицию, затем находится следующий наименьший элемент и помещается на вторую позицию и так далее, пока весь массив не будет отсортирован. Вот пример кода:

c
void selectionSort(int arr[], int n) {
    int i, j, minIndex, temp;
    for (i = 0; i < n - 1; i++) {
        minIndex = i;
        for (j = i + 1; j < n; j++) {
            if (arr[j] < arr[minIndex]) {
                minIndex = j;
            }
        }
        // меняем местами элементы
        temp = arr[minIndex];
        arr[minIndex] =  arr[i];
        arr[i] = temp;
    }
}

3. Сортировка вставками (Insertion Sort):

Этот метод представляет собой пошаговое упорядочивание элементов массива путем вставки каждого нового элемента в отсортированную часть массива. Вот пример кода:

c
void insertionSort(int arr[], int n) {
    int i, key, j;
    for (i = 1; i < n; i++) {
        key = arr[i];
        j = i - 1;
        
        while (j >= 0 && arr[j] > key) {
            arr[j + 1] = arr[j];
            j = j - 1;
        }
        
        arr[j + 1] = key;
    }
}

Это только несколько примеров сортировки массива в C. Существует и другие методы, такие как сортировка слиянием, быстрая сортировка и т.д. Выбор метода зависит от требований и особенностей конкретной задачи.

Похожие вопросы на: "сортировка массива в c "

Изучайте Bash – основную командную оболочку Linux
JS FormData: как использовать для отправки данных с формы
Creating a Beautiful Scatter Plot in Python with Matplotlib
For Lua: все, что вам нужно, чтобы стать профессиональным разработчиком Lua
Datalist - простой способ организации и отображения данных на вашем сайте
Преобразователь GIF в AVI онлайн
Как использовать массивы в VBA для обработки данных
Преобразование char в int в языке программирования C
Использование onclick css для создания интерактивности и стилизации элементов при клике
<h1>Convert PDF to PNG