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排序算法之快速排序(Quick Sort)及其优化算法详解

    PHP排序算法之快速排序(Quick Sort)及其优化算法详解 快速排序是一种高效的排序算法,也是PHP中常用的排序方法之一。在本攻略中,我们将介绍快速排序的基本思想与原理,以及一些优化算法和实际示例。 快速排序基本原理 快速排序的基本思想是:通过一趟排序将待排序记录分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据小,然后再按此方法对这两部…

    算法与数据结构 2023年5月19日
    00
  • 常用的 JS 排序算法 整理版

    下面是对“常用的JS排序算法 整理版”的完整攻略的详细讲解。 一、排序算法介绍 排序是计算机科学中的一个基本问题,它的目的是对一组元素进行升序或降序排列。JS中常用的排序算法包括 冒泡排序、选择排序、插入排序、希尔排序、归并排序、快速排序等。 二、常用排序算法示例 下面是两个常用排序算法的示例: 1. 冒泡排序 冒泡排序是一种简单的排序算法,它重复遍历要排序…

    算法与数据结构 2023年5月19日
    00
  • CSS规则层叠时的优先级算法

    当多个CSS规则(指选择器和声明的组合)作用于同一元素时,就会遇到规则层叠的问题,也就是优先级的问题。CSS规则层叠时的优先级算法主要分为以下4个级别: 元素样式或行内样式(Inline Style):元素样式指的是通过HTML元素的style属性定义的样式,行内样式(如在CSS中使用选择器设置)也具有同等优先级; ID选择器(ID Selector):指通…

    算法与数据结构 2023年5月19日
    00
  • 希尔排序算法的C语言实现示例

    下面是“希尔排序算法的C语言实现示例”完整攻略。 希尔排序算法简介 希尔排序是通过将整个待排序数组分割成多个子序列,对每个子序列进行插入排序,然后逐步减少子序列长度,最终使整个序列有序的一种算法。 希尔排序算法的流程 按照一定的间隔将待排序数组分成若干个子序列; 对每个子序列进行插入排序,使其中的元素可以快速有序; 缩小排序间隔,重复执行步骤1和2; 直至排…

    算法与数据结构 2023年5月19日
    00
  • C语言 冒泡排序算法详解及实例

    冒泡排序算法详解及实例 什么是冒泡排序算法 冒泡排序是一种很基础的排序算法,它通过从序列的一端开始,依次比较相邻两个元素的大小,如果它们的顺序不对,就交换它们的位置,直到把整个序列排序完成。冒泡排序算法的时间复杂度为O(n^2),所以它并不适合排序规模很大的序列。 冒泡排序算法的实现 冒泡排序算法的实现很简单,其核心代码如下: void bubble_sor…

    算法与数据结构 2023年5月19日
    00
  • C++中sort函数的基础入门使用教程

    以下是详细讲解“C++中sort函数的基础入门使用教程”的完整攻略及两条示例说明。 C++中sort函数的基础入门使用教程 简介 sort函数是C++ STL中的一个快速排序函数,我们可以用它对数组或容器进行排序。 基本使用 sort函数的一般形式如下: #include <algorithm> sort(first, last, cmp); 其…

    算法与数据结构 2023年5月19日
    00
  • C++实现广度优先搜索实例

    C++实现广度优先搜索实例攻略 什么是广度优先搜索? 广度优先搜索(Breadth-First Search,也称之为BFS)是一种基于图的搜索算法,用于访问位于某个特定顶点距离为K的所有顶点。它广泛应用于树和图的数据结构中。 BFS的过程如下: 从源节点开始遍历; 访问相邻的节点; 将相邻节点加入队列; 标记已访问的节点; 重复步骤2-4,直到队列为空。 …

    算法与数据结构 2023年5月19日
    00
  • C#常见算法面试题小结

    C#常见算法面试题小结 常见算法 本文主要讲解C#常见算法,在面试或实际工作中应用较为广泛。以下是本文讨论的常见算法: 排序算法 查找算法 贪心算法 动态规划算法 字符串算法 排序算法 冒泡排序 冒泡排序是一种效率低下的排序,但是学习它有助于了解其他的排序算法。 冒泡排序的核心思想是重复地走访过要排序的序列,每次比较相邻的两个元素,如果他们的顺序错误就把他们…

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