快速排序

//快速排序
#include<stdio.h>
void quicksoft(int low, int high);
int a[101];
int main()
{
    int i, n;
    scanf("%d",&n);
    for(i = 0; i < n; i++)
        scanf("%d",&a[i]);
    quicksoft(0,n-1);
    for(i = 0; i < n; i++)
        printf("%d ",a[i]);
}
void quicksoft(int low, int high)
{
    int first, i, j, t;//first 基准点
    first = a[low];
    i = low;
    j = high;
    if(low > high)
        return;
    while(i!=j)
    {
        while(a[j] >= first && i < j)//右边的数比基准点大且i<j时让j的位置一直减

            j--;

//a[j]出来的时候肯定是小于first

        while(a[i] <= first && i < j)

            i++;

//a[i]出来的时候肯定大于first

//这是我们交换a[i]和a[j]

        if(i < j)
        {
            t = a[j];
            a[j] = a[i];
            a[i] = t;
        }
    }
    a[low] = a[i];
    a[i] = first;//把基准点的值赋给a[i] 此时i == j 则左边都是小于first 右边都是大于first
    quicksoft(low,i-1);
    quicksoft(i+1,high);
}
全部评论

相关推荐

03-05 17:03
已编辑
浙江工商大学 C++
陈好好wy:整体看下来有点空空的感觉,可以把每一段项目经历都再完善一下,然后用小标题的形式写个两到三条,目前看有点太简单了,不太能看出具体在这个项目里做了什么工作。还是要尽量把自己做的工作以量化的形式体现在简历上呢。
双非本科求职如何逆袭
点赞 评论 收藏
分享
smile丶snow:感觉可以加一些ai相关的内容吧。现在面试很少能逃掉这些问题。羡慕里面感觉缺少一个项目背景。比如第二个项目后台管理系统…你为什么要做这个后台管理系统呢?是为了解决什么问题。比如你管理一个商品列表的增加减少。需要一个背景吧。哦或者说你第一个电子书那个是c端的,你肯定需要一个管理系统吧,那就是第二个后台管理系统,但这两个难道不应该是一个项目吗?可以稍微包装一下,最起码让人看着不是玩具项目。个人观点。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务