二维数组快速排序

<php

class Goods{

    //方法一:

    public static function main($data, $col)
    {
        $ardata = self::sortt($data, $col);
        return $ardata;
    }

    private static function sortt($data, $col)
    {
        if (count($data) <= 1) {
            return $data;
        }
        $tem = $data [0][$col];
        $leftarray = array();
        $rightarray = array();
        for ($i = 1; $i < count($data); $i++) {
            if ($data [$i][$col] <= $tem) {
                $leftarray[] = $data[$i];
            } else {
                $rightarray[] = $data[$i];
            }
        }
        $leftarray = self::sortt($leftarray, $col);
        $rightarray = self::sortt($rightarray, $col);
        $sortarray = array_merge($leftarray, array($data[0]), $rightarray);
        return $sortarray;
    }

    //方法二:
    /**
    * @param array $array 需要排序的数组
    * @param string $field 排序的字段
    * @param string $sort 排序顺序标志 SORT_DESC 降序;SORT_ASC 升序
    */
    public static function arraySequence($array, $field, $sort = 'SORT_DESC')
    {
        $arrSort = array();
        foreach ($array as $uniqid => $row) {
            foreach ($row as $key => $value) {
                $arrSort[$key][$uniqid] = $value;
            }
        }
        array_multisort($arrSort[$field], constant($sort), $array);
        return $array;
    }



}

//调用:
$goods=array(
array('id'=>1,'name'=>'T恤1','price'=>76),
array('id'=>1,'name'=>'T恤2','price'=>183),
array('id'=>1,'name'=>'T恤3','price'=>165),
array('id'=>1,'name'=>'T恤4','price'=>32), 
);  

//方法一:
print_r(Goods::sort($goods));

//方法二;
print_r(Goods::arraySequence($goods,'price','SORT_ASC'));
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值