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语言goto用法是什么

    在C语言中,goto语句用于从一个位置跳转到另一个位置。它可以用于跳出循环、条件语句或者函数。goto语句的语法如下:
    goto label;
    ...
    label: //...

  • goto在c语言中的运用方法是什么

    goto 语句在 C 语言中允许程序从一个位置跳转到另一个位置。然而,在实际编程中,过度使用 goto 语句通常被认为是一种不好的编程实践,因为它可能导致代码结构混...

  • c语言堆和栈的区别是什么

    C语言中的堆和栈是两种不同的内存分配方式。 栈(Stack):栈是由编译器自动分配和释放的内存区域,用于存储局部变量和函数调用的上下文信息。栈的特点是先进后出...

  • C语言结构体数组怎么定义和使用

    在C语言中,可以通过定义结构体数组来存储多个具有相同数据类型的结构体对象。下面是定义和使用结构体数组的示例代码:
    #include // 定义一个结构体类型

  • 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...