| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 645 人关注过本帖
标题:快速排序这两个函数具体怎样调用的,或者说这两个函数如何实现排序功能的
只看楼主 加入收藏
feiyue323
Rank: 2
等 级:论坛游民
威 望:1
帖 子:35
专家分:18
注 册:2016-9-16
结帖率:87.5%
收藏
已结贴  问题点数:20 回复次数:2 
快速排序这两个函数具体怎样调用的,或者说这两个函数如何实现排序功能的
程序代码:
void quick_sort(int s[], int l, int r)
{
    if (l < r)
    {
        //Swap(s[l], s[(l + r) / 2]); //将中间的这个数和第一个数交换 参见注1  
        int i = l, j = r, x = s[l];
        while (i < j)
        {
            while(i < j && s[j] >= x) // 从右向左找第一个小于x的数  
                j--;
            if(i < j)
                s[i++] = s[j];

            while(i < j && s[i] < x) // 从左向右找第一个大于等于x的数  
                i++;
            if(i < j)
                s[j--] = s[i];
        }
        s[i] = x;
        quick_sort(s, l, i - 1); // 递归调用   
        quick_sort(s, i + 1, r);
    }
}

快速排序这两个函数具体怎样调用的,或者说这两个函数如何实现排序功能的
quick_sort(s, l, i - 1); // 递归调用            
quick_sort(s, i + 1, r);  
2016-10-13 19:47
word123
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:13
帖 子:333
专家分:1622
注 册:2014-4-5
收藏
得分:10 
一个数组通过调用quick_sort分成左右两个部分,左边部分数据全部小于x   右边部分全部大于x,x是取得当前数组的范围的最左边的一个
然后调用
quick_sort(s, l, i - 1);
quick_sort(s, i + 1, r);
对x的左右两边执行同样的操作,直到数据个数为1不再递归,     因为if (l < r)不成立
现在对数组里的任意一个数x,左边的数小于x,右边的数大于x,数组现在是从小到大有序的了。
2016-10-13 22:24
linlulu001
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:20
帖 子:944
专家分:4047
注 册:2016-4-13
收藏
得分:10 
自己在纸上模拟运行一遍,基本上能理解它的运算过程,也能进一步了解递归函数,一举两得。就是得花点时间和心思。
2016-10-14 08:26
快速回复:快速排序这两个函数具体怎样调用的,或者说这两个函数如何实现排序功能 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.098791 second(s), 10 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved