快速排序大讲解(数组实现,链表实现,层次分析)

快速排序大讲解

思想

通过一趟的排序将需要排序的数组分成独立的两个部分,其中一部分都比基准值小,另一部分比基准值大

数组实现

因为数组是连续的存储空间,所以如果要将数组分成两个部分,需要用交换来完成.

void quick_sort(int *num, int l, int r) {
    if (r <= l) return ;
    int x = l, y = r, z = num[l];
    while (x < y) {
        while (x < y && num[y] >= z) --y;
        if (x < y) num[x++] = num[y];
        while (x < y && num[x] <= z) ++x;
        if (x < y) num[y--] = num[x];
    }
    num[x] = z;
    quick_sort(num, l, x - 1);
    quick_sort(num, x + 1, r);
    return ;
}
链表实现

链表是非连续的存储空间,是依靠指针去寻找下一个数组的位置的,所以需要用改变指针的指向来完成.

//没有有虚拟头节点,最后一个节点不参与排序
Node* quick_sort(Node *head, Node *tail){
    if(head == NULL) return NULL;
    //head是尾部,有一个节点,没结点
    if(head->next == NULL || head->next == tail || head == tail) return head;
    Node temp;//虚拟节点
    temp.next = head;
    Node *x = head, *y = tail, *z = head;
    while(x != y && x->next != NULL){
        while(x != y && x->next != NULL && x->next->data >= z->data) x = x->next;
        if(x != y && x->next != NULL){
            Node *inse = x->next;
            x->next = inse->next;
        
            inse->next = temp.next;
            temp.next = inse;
        }
    }
    //printf(" %d %d ",temp.next->data,z->data);
    temp.next = quick_sort(temp.next, z);
    z->next = quick_sort(z->next, NULL);
    return temp.next;
}
快速排序与二查排序树的联系

快速排序的每次处理是找到一个基准值,并且将数据以基准值为边界分为两部分,也可以称为两个集合.

二查排序树是以跟节点为界,根节点的左孩子都小于根,根节点的右孩子都大于根,也是两个集合

如果我们将二查排序树以每层的基准值为根节点将上层的基准值与下层的基准值进行连线,就会形成一个二叉排序树的结构.

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值