C语言的冒泡排序和快速排序算法使用实例

C语言的冒泡排序和快速排序算法使用实例

什么是排序算法

排序算法是一种将一组数据按照特定顺序排列的算法。常见的排序算法包括冒泡排序、快速排序、插入排序、选择排序等。

冒泡排序

冒泡排序是一种简单的排序算法,它重复地走访过要排序的元素,依次比较相邻两个元素,如果它们的顺序错误就交换它们的位置。重复这个过程,直到没有再需要交换的元素,即排序完成。

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

#include <stdio.h>

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

int main()
{
    int arr[] = { 5, 2, 8, 7, 1 };
    int len = sizeof(arr) / sizeof(arr[0]);
    bubble_sort(arr, len);
    for (int i = 0; i < len; i++)
    {
        printf("%d ", arr[i]);
    }
    return 0;
}

上面的程序中,bubble_sort 函数接收一个数组 arr 和数组的长度 len 作为参数,然后实现了冒泡排序。

打印结果为:1 2 5 7 8,即数组已经按照升序排列好了。

快速排序

快速排序是一种高效的排序算法,它基于分治法,能够将时间复杂度降至 O(n log n)。

以下是 C 语言实现快速排序的示例程序:

#include <stdio.h>

void quick_sort(int arr[], int left, int right)
{
    if (left >= right)
    {
        return;
    }
    int i = left, j = right, key = arr[left];
    while (i < j)
    {
        while (i < j && arr[j] >= key)
        {
            j--;
        }
        arr[i] = arr[j];
        while (i < j && arr[i] <= key)
        {
            i++;
        }
        arr[j] = arr[i];
    }
    arr[i] = key;
    quick_sort(arr, left, i - 1);
    quick_sort(arr, i + 1, right);
}

int main()
{
    int arr[] = { 5, 2, 8, 7, 1 };
    int len = sizeof(arr) / sizeof(arr[0]);
    quick_sort(arr, 0, len - 1);
    for (int i = 0; i < len; i++)
    {
        printf("%d ", arr[i]);
    }
    return 0;
}

上面的程序中,quick_sort 函数接收一个数组 arr、分区左端点 left 和分区右端点 right 作为参数,然后实现了快速排序。

打印结果为:1 2 5 7 8,即数组已经按照升序排列好了。

结论

从上面两个示例程序可以看出,无论是冒泡排序还是快速排序,它们的核心思想都是将需要排序的元素进行比较和交换。冒泡排序比较简单易懂,但时间复杂度较高。快速排序虽然时间复杂度低,但需要理解递归和分区的概念,较难掌握。

因此,在实际开发中,需要根据实际需求选择合适的排序算法。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:C语言的冒泡排序和快速排序算法使用实例 - Python技术站

(0)
上一篇 2023年5月19日
下一篇 2023年5月19日

相关文章

  • PHP四种基本排序算法示例

    关于“PHP四种基本排序算法示例”的完整攻略,我会从以下几个方面进行详细讲解: 排序算法的概念及分类 四种基本排序算法的原理及实现方式 示例说明:冒泡排序和快速排序 排序算法的概念及分类 排序算法是计算机科学中用于将一组数据按照特定顺序进行排列的算法,常用于数据的存储和查找。排序算法可分为内部排序和外部排序,内部排序就是将数据全部放入内存中进行排序,而外部排…

    算法与数据结构 2023年5月19日
    00
  • JavaScript中数组随机排序的实现详解

    下面是我对于“JavaScript中数组随机排序的实现详解”的完整攻略。 概述 在JavaScript中,数组是一个非常有用的数据类型,而随机排序是在处理数组时非常实用的一种技术。本攻略将为你详细讲解如何实现JavaScript数组的随机排序。 方法一:使用sort()方法 JavaScript中的数组包含一个sort()方法,可以对数组中的元素进行排序。我…

    算法与数据结构 2023年5月19日
    00
  • C语言实现排序算法之归并排序详解

    C语言实现排序算法之归并排序详解 概述 归并排序是一种分治算法,在处理大规模数据排序时具有较高的效率。该算法将要排序的数组分为两部分,对每个部分内部进行排序,然后将排好序的两部分合并成一个有序数组。该算法在实现时需要借助递归和迭代两种方式。 步骤 归并排序可递归或迭代实现。以下是递归实现的步骤: 分解:将待排序数组分为两个等长的子数组,分别为左半部分和右半部…

    算法与数据结构 2023年5月19日
    00
  • C语言常见排序算法之插入排序(直接插入排序,希尔排序)

    接下来我将为大家详细讲解“C语言常见排序算法之插入排序(直接插入排序, 希尔排序)”。 直接插入排序 算法思路 直接插入排序算法的实现思路是:将一个无序的数据序列分为一个有序子序列和一个无序子序列两部分,将无序子序列的元素一个一个插入到有序子序列中,直到插入完所有元素,最终形成一个新的有序序列。在具体编写代码时,我们会将数据序列看作是一个数组来进行操作。 代…

    算法与数据结构 2023年5月19日
    00
  • java图搜索算法之图的对象化描述示例详解

    Java图搜索算法之图的对象化描述示例详解 什么是图? 图是一种非线性数据结构,由节点和边组成,节点表示图中对象,边表示节点间相互关系。图分为有向图和无向图,有向边和无向边。 图的对象化描述 Java中可以使用对象化的方式来描述一个图,主要有两个类: Vertex(节点类) 节点类表示图中的节点,主要有两个属性: label:节点标签,用于区分不同节点。 w…

    算法与数据结构 2023年5月19日
    00
  • Java快速排序案例讲解

    Java快速排序案例讲解 快速排序(Quicksort)是一种常见的排序算法,它的时间复杂度为O(nlogn),是一种效率较高的排序算法,在实际开发中也广泛应用。本文将介绍Java快速排序的实现过程以及具体实现。 快速排序介绍 快速排序是通过选择一个“基准数”,然后把整个数组分成两部分,分别为小于等于“基准数”的部分和大于“基准数”的部分。然后再对这两个部分…

    算法与数据结构 2023年5月19日
    00
  • JS实现最简单的冒泡排序算法

    JS实现最简单的冒泡排序算法 冒泡排序是最简单的排序算法之一,它的基本思路是反复遍历待排序的元素,比较相邻的元素并交换,直到没有元素需要交换为止。 实现思路 以下是实现冒泡排序算法的基本思路: 定义一个数组a,长度为n,n为待排序的元素数量。 嵌套两层循环,外层循环控制遍历的次数n-1,内层循环控制每次遍历中相邻元素的比较和交换。 每次遍历,从数组的第一个元…

    算法与数据结构 2023年5月19日
    00
  • Javascript实现快速排序(Quicksort)的算法详解

    Javascript实现快速排序的算法详解 在这个攻略中,我们将通过Javascript实现快速排序算法,并讲解算法的详细过程。 快速排序的基本思想 快速排序是一种基于交换的排序算法,其基本思想是通过选择一个基准元素,在一趟排序过程中,将之前需要排序的序列中的元素分割成两个部分,其中,左边部分元素的值都小于基准元素的值,右边部分元素的值都大于基准元素的值,然…

    算法与数据结构 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部