鱼C论坛

 找回密码
 立即注册

quick sort 快速排序

已有 343 次阅读2019-11-25 21:03

#include <stdio.h>

void quick_sort (int ls[] , int first , int last)
{
    if (first > last)
    {
        return ;
    }
    int i = first ;
    int j = last ;
    int tmp ;
    while (i != j)
    {
        while (ls[j] >= ls[first] && i < j)
        {
            j-- ;
        }
        while (ls[i] <= ls[first] && i < j)
        {
            i++ ;
        }
        if (i<j)
        {   tmp = ls[i];
            ls[i] = ls[j];
            ls[j] = tmp ;
        }
    }
    tmp = ls[i] ;
    ls[i] = ls[first] ;
    ls[first] = tmp ;
    quick_sort(ls, first , i-1);
    quick_sort(ls, i+1 , last);
    return ;
}

int main ()
{
    int i , size ;
    printf("please input some value\n");
    scanf("%d",&size);
    int ls[size+1] ;
    for ( i = 1 ; i <= size ; i++ )
    {
        scanf("%d",&ls[i]);
    }
    quick_sort(ls,1,size);
    for (i = 1 ; i <= size ; i++)
    {
        printf("%d ",ls[i]);
    }
    return 0 ;
}

路过

鸡蛋

鲜花

握手

雷人

评论 (0 个评论)

facelist

您需要登录后才可以评论 登录 | 立即注册

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-17 03:11

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

返回顶部