快速排序(C/C++)

什么是快速排序?

快速排序是一种交换排序,交换就是根据序列中的两个记录键值的比较结果来兑换这两个记录在序列中的位置,交换排序的特点是:将键值较大的记录向序列的尾部移动,键值较小的记录向序列的前部移动。

快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法,其基本思想为:任取待排序元素序列中的某元素作为基准值,按照该排序码将待排序集合分割成两子序列,左子序列中所有元素均小于基准值,右子序列中所有元素均大于基准值,然后最左右子序列重复该过程,直到所有元素都排列在相应位置上为止。

快速排序的流程

  1. 记录数组第一个元素位置(low)和最后一个元素(high)

  1. 选取一个值作为中心值,保存在临时变量temp中,这里我们选取第一个元素作为中心值。

这里可以看作数组第一个位置是空出来的(第一个位置的值已经保存到了temo中)。从右边选取第一个小于temp的值填到第一个位置来。

  1. 从最右边找起来,找到一个小于temp的数,找到了便填到第一个位置来,如果找不到,则说明右边所有的数都比temp大,则跳出循环,代码条件为left < right && arr[right] >= temp

while(left < right && arr[right] >= temp)
{
    --right;
}
arr[left] = arr[right];

此时的数组:

从图片上我们可知右边right已经空出来了,所以我们要从左边开始找

  1. 从left开始找比temp大的数,填到右边去,代码条件left < right && arr[left] <= temp

while(left < right && arr[left] <= temp)
{
    ++left;
}
arr[right] = arr[left];

从左边找起,第一个位置上的已经变成为0,小于temp,left++,当left移动到8位置上,发现大于temp,所以不满足循环条件,执行arr[right] = arr[left]。

==》

左边又空出来,所以得从右边right当前位置接着开始找下一个小于temp的数填到左边空出来的位置上去,所以重复了上边第3步的步骤,当第3步中把右边的数填到左边后,又会重复第四步,于是有了第5步。

  1. 我们把第3步和第4步 的代码再用一个while循环包起来。

while(left < right)
{
    while(left < right && arr[right] >= temp)
    {
        --right;
    }
    arr[left] = arr[right];

    while(left < right && arr[left] <= temp)
    {
        ++left;
    }
    arr[right] = arr[left];
}

当所有的数被遍历完了,left和right便会相等,这时我们就不需要比较了。

我们发现有一个位置空出来了,于是我们用最开始拿出来的中心值填进去,你会发现左边的值都小于temp,右边的值都大于temp。

第一轮排序就这样完成了

0

1

2

6

4

3

9

8

7

5

  1. 便是递归排序了

my_sort(arr,low,lfet-1);

my_sort(arr,left+1,high);

我们把0,1扔到my_sort中里面在排序一遍,把6,4,3,9,8,7,5扔到my_sort里面也排序一遍,重复这个操作,这个便是递归。

完整代码

代码为C++实现,学习C语言的同学也能看懂

#include <iostream>
using namespace std;

//交换函数
void sort_realize(int* p,int left,int right)
{
    if(left > right)
    {
        return;
    }
    //1.首先先记录数组的最左边和最右边元素下标
    int low = left;//记录最左边元素下标
    int high = right;//记录最右边的元素下标

    //2.随便选取一个中心值
    int temp = p[low];//中心值
//此时中心值已经被temp变量记住,所以该位置可以被其他元素覆盖,也就是说该位置为一个空缺状态

    //3.循环交换位置
    while(low < high)
    {
        //从右边开始找比中心值小的数顶替到左边空缺的位置上
        //顶替完成后右边顶替的那个元素位置相当于也变成空缺的了
        while(low < high && p[high] >= temp)
        {
            --high;
        }
        p[low] = p[high];

        //从左边边开始找比中心值大的数顶替到右边空缺的位置上
        //顶替完成后左边顶替的那个元素位置相当于也变成空缺的了
        while(low < high && p[low] <= temp)
        {
            ++low;
        }
        p[high] = p[low];
    }

    //4.当所有的数遍历完后,low==high所指向的位置就是中心值填入的位置
    p[high] = temp;

    //5.开始递归交换位置
    //每次一的调用其实都是确定好了中心值的位置,想要全部确定好也就是说全部元素都要当一回中心值
    sort_realize(p,0,high-1);
    sort_realize(p,high+1,right);
}

//打印函数
void Print(int *p,int len)
{
    for(int i = 0;i < len;i++)
    {
        cout << p[i] << " ";
    }
    cout << endl;
}

int main()
{
    //先创建一个数组
    int p[10] = {0};

    for(int i = 0;i < 10;i++)
    {
        int num;
        cin >> num;//从键盘输入数字
        p[i] = num;
    }
    //将数组传递进行排序
    int len = sizeof(p) / sizeof(int);
    sort_realize(p,0,len-1);
    Print(p,len);
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 《算法笔记》是由胡凡编写的一本关于算法学习的教材,它最初以C/C++为主要编程语言。这本教材主要面向想要学习算法的初学者,以及希望进一步提升算法能力的人群。 《算法笔记》的内容广泛而且深入,涵盖了很多算法的基础知识和主要思想,如递归、排序、查找、图论、动态规划等。通过学习这本教材,读者可以掌握这些算法的基本原理和实现方法,提高解决实际问题的能力。 该教材有几个特点:首先,它提供了很多例子和习题,帮助读者巩固所学的知识;其次,它介绍了很多常用的数据结构,如数组、链表、栈、队列等,读者可以通过学习这些数据结构更好地理解和应用算法;最后,它还介绍了一些高级主题,如高级数据结构、算法优化等,这些内容对于进一步提升算法水平非常有帮助。 《算法笔记》是一本入门级的教材,因此在阅读时需要一些基本的编程知识和逻辑思维能力。该教材的语言简洁明快,适合作为学习参考书,同时也可以作为算法竞赛的辅助教材。 总而言之,《算法笔记》是一本很好的算法学习教材,它以C/C++为编程语言,全面介绍了算法的基本知识和常用方法,适合想要学习算法的初学者。无论是学术研究还是实际应用,阅读《算法笔记》都能提升算法能力,并为进一步学习和应用算法打下坚实的基础。 ### 回答2: 《算法笔记 胡凡 c/c 快速入门pdf》是一本介绍算法和C/C++编程语言的入门书籍。该书的作者是胡凡,它主要规划了算法的学习路径以及基本的C/C++编程语言。这本书适合初学者快速入门,对于想要系统学习算法和C/C++编程的人来说是一本不错的选择。 这本书的内容非常系统和全面。它以算法和数据结构为基础,包括基本排序、查找、图论等算法的介绍和实践,让读者能够快速掌握这些算法的原理和实现方法。同时,它还介绍了C/C++语言的基础知识和编程技巧,帮助读者理解和运用这些知识。 书中每章都有一些练习题,帮助读者巩固所学的知识。同时,每个章节末尾还提供了一些进阶的题目和参考答案,供读者深入学习和自我检测。这样的设计能够帮助读者更好地理解和掌握所学的内容。 总的来说,《算法笔记 胡凡 c/c 快速入门pdf》是一本很好的算法和C/C++入门书籍。它能够帮助读者快速了解算法和数据结构的基础知识,并学会使用C/C++语言进行编程。无论是对于想要入门算法和C/C++编程的初学者,还是已经有一定基础的读者,这本书都是一个很好的选择。 ### 回答3: 《算法笔记:胡凡C/C++快速入门PDF》是一本很棒的入门算法书籍。这本书主要介绍了常用的数据结构与算法,并通过C/C++语言来实现这些算法。 首先,这本书非常适合算法初学者。它从基础的数据结构开始讲解,如数组、链表、栈和队列,然后逐渐引入更复杂的数据结构,如二叉树、图和堆。此外,书中还介绍了常用的排序和查找算法,如冒泡排序、快速排序、二分查找等。每个算法都配有具体的代码实现和详细的解释,帮助读者理解算法的原理和应用。 其次,这本书的学习资料丰富。书中提供了很多例题和习题,读者可以通过实践来巩固所学的知识。此外,书中还介绍了一些常见的算法优化技巧和设计思路,提供了一些高效解决问题的方法和思考方式。 最后,这本书的编写风格简明易懂。作者通过清晰的语言和简洁的代码,将复杂的算法问题简化为易于理解的部分。不论是对于算法初学者还是对于有一定编程基础的读者,这本书都是一本很好的学习资料。 总而言之,《算法笔记:胡凡C/C++快速入门PDF》是一本很好的入门算法书籍。它适合初学者学习和理解常用的数据结构与算法,通过具体的代码实现和详细的解释帮助读者掌握算法的原理和应用。无论是编程初学者还是有一定基础的读者,都可以从这本书中获得丰富的知识和实践经验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值