博主信息
博文 8
粉丝 0
评论 0
访问量 7171
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
冒泡排序与快速排序
柯二南的博客
原创
746人浏览过
<?php
class ArraySort{
    /*
     * author:wency;
     * name:initRand
     * purpose:快速产生一组随机数
     * @parameter  $length  长度
     * @parameter $low  int  最小数
     * @parameter $high  int 最大数
     * return:$X array
     */

    public function initRand($length, $low, $high) {

        for ($i = 0; $i < $length; $i++) {
            $arrX[] = rand($low, $high);
        }
        $X = $arrX;
        echo '<pre>';
        return ($X);
    }

    /*
     * author:wency;
     * name:bubble_sort
     * purpose:冒泡排序
     * @parameter  $X array
     * return:$X array
     */

    public function bubble_sort(&$X) {
        $count = count($X);
        for ($j = 0; $j < $count; $j++) {
            for ($i = 0; $i < $count - $j - 1; $i++) {
                if ($X[$i] > $X[$i + 1]) {
                    $temp = $X[$i];
                    $X[$i] = $X[$i + 1];
                    $X[$i + 1] = $temp;
                }
            }
        }
        return $X;
    }

    /*
     * author:wency;
     * name:quick_sort
     * purpose:快速排序
     * @parameter  $array array
     * return:$array array
     */

    public function quick_sort($array) {
        if (count($array) <= 1) {
            return $array;
        }
        $key = $array[0];
        $left = [];
        $right = [];
        for ($i = 1; $i < count($array); $i++) {
            if ($array[$i] < $key) {
                $left[] = $array[$i];
            } else {
                $right[] = $array[$i];
            }
        }
        $left = $this->quick_sort($left);
        $right = $this->quick_sort($right);
        return array_merge($left, array($key), $right);
    }

}
$obj = new ArraySort;
$newArray = $obj->initRand(20, 1, 100);
echo '<pre>';
print_r($newArray);
echo '<pre>';
//$arrX = $obj->bubble_sort($newArray);
$arrX = $obj->quick_sort($newArray);
print_r($arrX);

可以先调用类中的initRand()方法快速产生一组随机数组,再调用两个排序方法bubble_sort()和quick_sort()进行排序

本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!
全部评论 文明上网理性发言,请遵守新闻评论服务协议
0条评论
作者最新博文
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

  • 登录PHP中文网,和优秀的人一起学习!
    全站2000+教程免费学