当前位置:首页 > 行业动态 > 正文

怎么用c语言进行3个数的排序

在C语言中,我们可以使用多种方法对3个数进行排序,这里我将介绍两种常见的方法:冒泡排序和选择排序。

冒泡排序

冒泡排序是一种简单的排序算法,它重复地遍历要排序的数列,一次比较两个元素,如果他们的顺序错误就把他们交换过来,遍历数列的工作是重复地进行直到没有再需要交换,也就是说该数列已经排序完成。

以下是冒泡排序的C语言实现:

#include <stdio.h>
void bubbleSort(int arr[], int n) {
    for (int i = 0; i < n1; i++) {     
        for (int j = 0; j < ni1; j++) { 
            if (arr[j] > arr[j+1]) {
                // 交换 arr[j] 和 arr[j+1]
                int temp = arr[j];
                arr[j] = arr[j+1];
                arr[j+1] = temp;
            }
        }
    }
}
int main() {
    int arr[] = {64, 34, 25};
    int n = sizeof(arr)/sizeof(arr[0]);
    bubbleSort(arr, n);
    printf("排序后的数组: n");
    for (int i=0; i < n; i++)
        printf("%d ", arr[i]);
    return 0;
}

选择排序

选择排序是一种简单直观的排序算法,它的工作原理如下:首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾,以此类推,直到所有元素均排序完毕。

以下是选择排序的C语言实现:

#include <stdio.h>
void selectionSort(int arr[], int n) {
    int i, j, min_idx;
    for (i = 0; i < n1; i++) {
        min_idx = i;
        for (j = i+1; j < n; j++)
            if (arr[j] < arr[min_idx])
                min_idx = j;
        // 交换 arr[min_idx] 和 arr[i]
        int temp = arr[min_idx];
        arr[min_idx] = arr[i];
        arr[i] = temp;
    }
}
int main() {
    int arr[] = {64, 34, 25};
    int n = sizeof(arr)/sizeof(arr[0]);
    selectionSort(arr, n);
    printf("排序后的数组: n");
    for (int i=0; i < n; i++)
        printf("%d ", arr[i]);
    return 0;
}

以上就是使用C语言进行3个数排序的方法。

0