117.info
人生若只如初见

c语言怎么实现从小到大排序

在C语言中,可以使用冒泡排序、选择排序、插入排序等多种方法实现从小到大的排序。以下是使用冒泡排序和选择排序两种方法的示例代码:

  1. 冒泡排序:
#include 

void bubbleSort(int arr[], int n) {
    int i, j, temp;
    for (i = 0; i < n-1; i++) {
        for (j = 0; j < n-i-1; j++) {
            if (arr[j] > arr[j+1]) {
                temp = arr[j];
                arr[j] = arr[j+1];
                arr[j+1] = temp;
            }
        }
    }
}

int main() {
    int arr[] = {64, 34, 25, 12, 22, 11, 90};
    int n = sizeof(arr) / sizeof(arr[0]);
    bubbleSort(arr, n);
    printf("Sorted array: \n");
    for (int i=0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    return 0;
}

输出结果:

Sorted array:
11 12 22 25 34 64 90
  1. 选择排序:
#include 

void selectionSort(int arr[], int n) {
    int i, j, min_idx, temp;
    for (i = 0; i < n-1; i++) {
        min_idx = i;
        for (j = i+1; j < n; j++) {
            if (arr[j] < arr[min_idx]) {
                min_idx = j;
            }
        }
        temp = arr[min_idx];
        arr[min_idx] = arr[i];
        arr[i] = temp;
    }
}

int main() {
    int arr[] = {64, 34, 25, 12, 22, 11, 90};
    int n = sizeof(arr) / sizeof(arr[0]);
    selectionSort(arr, n);
    printf("Sorted array: \n");
    for (int i=0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    return 0;
}

输出结果:

Sorted array:
11 12 22 25 34 64 90

这里只是介绍了两种常见的排序算法,还有其他更高效的排序算法,如快速排序和归并排序等,可以根据需求选择合适的算法。

未经允许不得转载 » 本文链接:https://www.117.info/ask/fefbaAzsLAgJVA1Y.html

推荐文章

  • C语言中getchar函数的功能有哪些

    C语言中getchar函数的功能有以下几点: 从标准输入流(通常是键盘)读取一个字符并返回。
    可以用于逐字符读取用户输入的数据。
    可以用于逐字符读取文件...

  • c语言逆序数如何输出

    C语言逆序数的输出可以通过以下步骤实现: 定义一个整数数组来存储输入的数字序列。
    使用循环语句将数字依次存储到数组中。
    使用另一个循环语句,从数...

  • c语言trim去掉不了空格怎么解决

    在C语言中,可以使用循环遍历字符串的每个字符,并判断是否为空格来实现去掉空格的操作。以下是一个示例代码:
    #include #include void trim(char *str) { ...

  • c语言createlist函数如何声明

    在C语言中,可以使用以下方式声明createlist函数:
    struct ListNode { int val; struct ListNode *next;
    }; struct ListNode* createlist(int arr[], ...

  • c语言怎么实现排列组合算法

    C语言实现排列组合算法可以使用递归或迭代的方式来实现。以下是使用递归实现排列组合算法的示例代码:
    #include // 计算阶乘
    int factorial(int n) { ...

  • linux更改用户组的方法是什么

    在Linux中,可以使用以下几种方法来更改用户的组: usermod命令:使用usermod命令可以修改用户的属性,包括用户组。具体命令如下:
    usermod -g 新组 用户名...

  • windows的curl命令如何卸载

    要在Windows上卸载curl命令,可以按照以下步骤进行操作: 打开控制面板:按下Win + X键,然后选择"控制面板"选项。
    在控制面板中,选择"程序"或"程序和功能...

  • linux拷贝到当前目录的方法是什么

    在Linux中,要将文件或目录拷贝到当前目录,可以使用以下命令:1. 拷贝文件到当前目录: cp /path/to/file . 或者 cp /path/to/file ./filename 将"/path/to/fil...