PHP二维数组排序算法函数

以使用PHP内置的array_multisort()函数来对二维数组进行排序。array_multisort()函数可以对多个数组或多维数组的一个或多个列进行排序。下面是一个示例函数,该函数可以对二维数组按指定列进行排序:

php 复制代码
<?php
function sort2DArrayByColumn(&$array, $columnKey, $sortOrder = SORT_ASC) {
    // 提取出需要排序的列
    $columnValues = array_column($array, $columnKey);

    // 使用 array_multisort 对二维数组进行排序
    array_multisort($columnValues, $sortOrder, $array);
}

// 示例用法
$data = [
    ['name' => 'John', 'age' => 30, 'salary' => 5000],
    ['name' => 'Jane', 'age' => 25, 'salary' => 6000],
    ['name' => 'Doe', 'age' => 35, 'salary' => 4000],
];

echo "排序前:\n";
print_r($data);

// 按 'age' 列升序排序
sort2DArrayByColumn($data, 'age');

echo "\n按 'age' 列升序排序后:\n";
print_r($data);

// 按 'salary' 列降序排序
sort2DArrayByColumn($data, 'salary', SORT_DESC);

echo "\n按 'salary' 列降序排序后:\n";
print_r($data);
?>

代码解释:

  1. 函数定义
    • sort2DArrayByColumn(&$array, $columnKey, $sortOrder = SORT_ASC)
      • &$array:传引用传递二维数组,排序后原数组会被修改。
      • $columnKey:指定要排序的列名。
      • $sortOrder:排序顺序,默认为升序(SORT_ASC),可选降序(SORT_DESC)。
  2. 提取列值
    • array_column($array, $columnKey):提取出二维数组中指定列的所有值。
  3. 排序
    • array_multisort($columnValues, $sortOrder, $array):根据提取出的列值对二维数组进行排序。
  4. 示例用法
    • 创建一个二维数组$data
    • 打印排序前的数组。
    • 'age'列升序排序并打印结果。
    • 'salary'列降序排序并打印结果。

运行该代码后,你会看到数组按照指定的列和顺序进行了排序。

相关推荐
琹箐10 分钟前
最大堆和最小堆 实现思路
java·开发语言·算法
renhongxia139 分钟前
如何基于知识图谱进行故障原因、事故原因推理,需要用到哪些算法
人工智能·深度学习·算法·机器学习·自然语言处理·transformer·知识图谱
坚持就完事了40 分钟前
数据结构之树(Java实现)
java·算法
算法备案代理42 分钟前
大模型备案与算法备案,企业该如何选择?
人工智能·算法·大模型·算法备案
赛姐在努力.1 小时前
【拓扑排序】-- 算法原理讲解,及实现拓扑排序,附赠热门例题
java·算法·图论
qq_353737541 小时前
网站评分系统API
php
huaweichenai1 小时前
中国工商银行支付对接
php
搂着猫睡的小鱼鱼2 小时前
Ozon 商品页数据解析与提取 API
爬虫·php
野犬寒鸦2 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
霖霖总总2 小时前
[小技巧66]当自增主键耗尽:MySQL 主键溢出问题深度解析与雪花算法替代方案
mysql·算法