鱼C论坛

 找回密码
 立即注册
查看: 5063|回复: 6

快速排序算法

[复制链接]
发表于 2016-3-28 12:23:14 | 显示全部楼层 |阅读模式
20鱼币
看了小甲鱼的快速排序算法,有一部分不懂,就是如视频后留的问题:
#include <stdio.h>

void swap(int k[], int low, int high)
{
        int temp;

        temp = k[low];
        k[low] = k[high];
        k[high] = temp;
}

int Partition(int k[], int low, int high)
{
        int point;

        point = k[low];

        while( low < high )
        {
                while( low < high && k[high] >= point )//这里为何是>=,>号完全可以啦,不懂求解释
       
                        high--;
                }
                swap(k, low, high);
               
                while( low < high && k[low] <= point )//这里为何是<=,<号完全可以啦,不懂求解释
                {
                        low++;
                }
                swap(k, low, high);
        }
   
        return low;
}

void QSort(int k[], int low, int high)
{
        int point;

        if( low < high )
        {
                point = Partition(k, low, high);

                QSort(k, low, point-1);

                QSort(k, point+1, high);
        }
}

void QuickSort(int k[], int n)
{
        QSort(k, 0, n-1);
}

int main()
{
        int i, a[10] = {4, 2, 5, 0, 3, 9, 1, 7, 6, 8};

        QuickSort(a, 10);

        printf("排序后的结果是:");
        for( i=0; i < 10; i++ )
        {
                printf("%d", a[i]);
        }
        printf("\n\n");

        return 0;
}

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2016-3-28 17:34:40 | 显示全部楼层
假如要排的数是1 3 5 2 2 7 8    while( low < high && k[5]=2 >= 2)        ((high=5)--)=4;也就是
k[4]=2
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2016-3-29 08:57:04 | 显示全部楼层
快速排序是不稳定算法,就是原来相同的值,位置会变化。所以大于等于号,是针对算饭稳定不稳定来说的吧。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2016-3-29 14:34:50 | 显示全部楼层
emrson 发表于 2016-3-28 17:34
假如要排的数是1 3 5 2 2 7 8    while( low < high && k[5]=2 >= 2)        ((high=5)--)=4;也就是
k ...

大哥数组是从0开始的,k[5]=7,在说当数值相等时,比如你这个例子中的
k[3] = k[4] = 2,用快速排序不影响最后的结果的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2016-3-29 14:36:07 | 显示全部楼层
jzh823 发表于 2016-3-29 08:57
快速排序是不稳定算法,就是原来相同的值,位置会变化。所以大于等于号,是针对算饭稳定不稳定来说的吧。

知道是不稳定的算法,但是能不能举个特殊的反例,帮我解释下,太抽象的不好理解
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2016-3-31 10:27:20 | 显示全部楼层
代码表示看不懂,能搞简单搞简单点,别一层套一层,这样速度回拖慢好多倍!
>= 或者>这个是在比较,这个是看相等的数是放在左边还是右边!不管左边还是右边,都一样!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-1-7 15:32:36 | 显示全部楼层
代码看不太明白
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-11-26 20:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表