数据结构和算法(15):快速排序

基本概念

快速排序( Quick Sort)的基本思想是: 通过一趟排序将待排记录分割成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,则可分别对这两部分记录继续进行排序,以达到整个序列有序的目的。

快速排序算法最早是由图灵奖获得者Tony Hoare设计出来的,他在形式化方法理论以及ALGOL60 编程语言的发明中都有卓越的贡献,是20世纪最伟大的计算机科学家之一。而这快速排序算法只是他众多贡献中的一个小发明而已。

希尔排序相当于直接插入排序的升级,它们同属于插入排序类,堆排序相当于简单选择排序的升级,它们同属于选择排序类。而快速排序其实就是我们前面认为最慢的冒泡排序的升级,它们都属于交换排序类。即它也是通过不断比较和移动交换来实现排序的,只不过它的实现,增大了记录的比较和移动的距离,将关键字较大的记录从前面直接移动到后面,关键字较小的记录从后面直接移动到前面,从而减少了总的比较次数和移动交换次数

具体的实现步骤如下:

  1. 选择基准元素pivot。
  2. 设置左指针left指向数组的起始位置,设置右指针right指向数组的末尾位置。
  3. 移动左指针left,直到找到一个大于等于pivot的元素。
  4. 移动右指针right,直到找到一个小于等于pivot的元素。
  5. 如果left小于等于right,则交换left和right指针所指向的元素。
  6. 重复步骤 3 和 4,直到left大于right。
  7. 此时,将基准元素pivot与right指针指向的元素交换位置。经过这一步操作,基准元素将位于合适的位置,左边的元素都比pivot小,右边的元素都比pivot大。
  8. 递归地对基准元素左边的子数组和右边的子数组进行快速排序。
  9. 递归结束的条件是子数组的大小为1或0,因为只有一个元素或者没有元素时,它们已经是有序的。

视频教程

【秒懂算法快速排序-动画4分钟精讲】 https://www.bilibili.com/video/BV1K44y1k79z/?share_source=copy_web&vd_source=38ed12eb64a70618ffa8e44b3d5eadf6

【全网最清晰快速排序,看完快排思想和代码全部通透,不通透你打我!】 https://www.bilibili.com/video/BV1vP411g7J3/?share_source=copy_web&vd_source=38ed12eb64a70618ffa8e44b3d5eadf6

using System;

class QuickSort
{
    static void Main(string[] args)
    {
        int[] array = { 9, 2, 5, 1, 7, 4, 8, 6, 3 };

        Console.WriteLine("Original Array: ");
        PrintArray(array);

        QuickSortAlgorithm(array, 0, array.Length - 1); // 调用快速排序算法

        Console.WriteLine("\nSorted Array: ");
        PrintArray(array);
    }

    static void QuickSortAlgorithm(int[] array, int left, int right)
    {
        if (left < right)
        {
            int pivotIndex = Partition(array, left, right); // 获取基准元素的位置

            // 递归地对基准元素左边的子数组和右边的子数组进行快速排序
            QuickSortAlgorithm(array, left, pivotIndex - 1);
            QuickSortAlgorithm(array, pivotIndex + 1, right);
        }
    }

    static int Partition(int[] array, int left, int right)
    {
        int pivot = array[right]; // 选择最右边的元素作为基准元素
        int i = left - 1; // 初始化左指针

        for (int j = left; j < right; j++)
        {
            if (array[j] < pivot)
            {
                i++;
                Swap(array, i, j); // 将小于基准元素的元素放到左边
            }
        }

        Swap(array, i + 1, right); // 将基准元素放到合适的位置
        return i + 1; // 返回基准元素的位置
    }

    static void Swap(int[] array, int i, int j)
    {
        int temp = array[i];
        array[i] = array[j];
        array[j] = temp;
    }

    static void PrintArray(int[] array)
    {
        foreach (int num in array)
        {
            Console.Write(num + " ");
        }
        Console.WriteLine();
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值