Perl 快排

看了下算法导论中的快排,实现方法不太一样,重新练习一下。

如图为比较过程中的移动:


代码:

# 递归
sub qsort2 {
    return () unless @_;
    (
        qsort( grep        { $_ < $_[0] } @_[ 1 .. $#_ ] ),
        $_[0], qsort( grep { $_ >= $_[0] } @_[ 1 .. $#_ ] )
    );
}

# 非递归
sub qsort {
    if ( !@_ ) {
        return ();
    }
    else {

        # 以$_[0] 作为基准比较,前后两个方向逼近,不象算法导论中单向向右逼近
        my $low  = 1;
        my $high = $#_;
        while ( $high >= $low ) {
            while ( $low <= $high && $_[$low] < $_[0] ) {
                $low++;
            }
            while ( $high >= $low && $_[$high] >= $_[0] ) {
                $high--;
            }
            print "@_ => $low $high\n";
            if ( $low < $high ) {
                ( $_[$low], $_[$high] ) = ( $_[$high], $_[$low] );
            }
            print "@_ \n";
        }

        # 与基准位的判断,不同则互换
        if ( $high != 0 ) { ( $_[0], $_[$high] ) = ( $_[$high], $_[0] ) }
        print "----------\n@_\n---------- \n";
        qsort( @_[ 0 .. ( $high - 1 ) ] );
        qsort( @_[ ( $high + 1 ) .. $#_ ] );
    }
}

@a = map { int rand 100 } 1 .. 10;
print "@a\n";
qsort(@a);
print "@a\n";


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值