0

0

PHP中根据关联值对数组进行排序的教程

花韻仙語

花韻仙語

发布时间:2025-12-14 15:40:23

|

818人浏览过

|

来源于php中文网

原创

PHP中根据关联值对数组进行排序的教程

php开发中,我们经常会遇到需要对一个数组进行排序,但排序的依据却来源于另一个相关联的数组。一个典型的场景是,我们有一个包含元素列表的数组,以及另一个包含这些元素对应“权重”或“频率”的数组,目标是根据这些权重对第一个数组的元素进行重新排列。本教程将深入探讨如何高效地解决这类问题,利用php内置函数实现基于关联值的数组排序。

理解问题背景

假设我们有两个等长的数组:

  • $elements:包含一系列需要排序的元素,例如英文字母 'a', 'b', 'c', ...。
  • $values:包含与$elements中每个元素对应的值,例如这些字母在文本中出现的频率 168, 118, ...。

我们的目标是根据$values数组中的频率(通常是从高到低)来重新排列$elements数组中的字母。直接对$elements或$values进行排序并不能直接满足需求,因为我们需要保持两个数组元素之间的对应关系。

解决方案核心思路

解决此问题的关键在于将两个数组的对应关系“固化”在一个数据结构中,然后对这个结构进行排序。PHP提供了一个非常适合此场景的解决方案:

  1. 合并数组: 使用array_combine()函数将两个数组合并为一个关联数组,其中一个数组的元素作为键,另一个数组的元素作为值。
  2. 关联排序: 对合并后的关联数组进行排序,根据值的大小重新排列键值对

步骤详解与代码示例

1. 合并数组:使用 array_combine()

array_combine()函数用于创建一个新数组,使用第一个数组的值作为新数组的键,第二个数组的值作为新数组的值。这个函数要求两个输入数组的元素数量必须相同,否则会返回false。

立即学习PHP免费学习笔记(深入)”;

语法: array_combine(array $keys, array $values): array

示例:

<?php
$elements = ['a', 'b', 'c', 'd', 'e'];
$values = [500, 600, 90, 120, 90];

// 将 $elements 作为键, $values 作为值,创建关联数组
$combinedArray = array_combine($elements, $values);

echo "合并后的关联数组:\n";
print_r($combinedArray);
/*
输出:
合并后的关联数组:
Array
(
    [a] => 500
    [b] => 600
    [c] => 90
    [d] => 120
    [e] => 90
)
*/
?>

通过array_combine(),我们成功地将字母与其对应的频率关联起来,形成了'a' => 500, 'b' => 600这样的键值对。

2. 关联排序:使用 arsort() 或 asort()

合并成关联数组后,我们就可以使用PHP的关联排序函数来根据值进行排序,同时保持键与值之间的关联。

AIBox 一站式AI创作平台
AIBox 一站式AI创作平台

AIBox365一站式AI创作平台,支持ChatGPT、GPT4、Claue3、Gemini、Midjourney等国内外大模型

下载
  • arsort() (Associate Reverse Sort): 根据值对关联数组进行降序排序(从大到小),并保持键与值的关联。
  • asort() (Associate Sort): 根据值对关联数组进行升序排序(从小到大),并保持键与值的关联。

由于我们通常希望频率高的字母排在前面,所以arsort()是更常见的选择。

示例:

<?php
$elements = ['a', 'b', 'c', 'd', 'e'];
$values = [500, 600, 90, 120, 90];

$combinedArray = array_combine($elements, $values);

// 使用 arsort() 对合并后的数组按值进行降序排序
arsort($combinedArray);

echo "\n按频率降序排序后的关联数组:\n";
print_r($combinedArray);
/*
输出:
按频率降序排序后的关联数组:
Array
(
    [b] => 600
    [a] => 500
    [d] => 120
    [c] => 90
    [e] => 90
)
*/
?>

可以看到,数组已经按照频率从高到低进行了排序,并且每个字母(键)仍然与其正确的频率(值)关联。

3. 提取排序后的元素(可选)

如果最终我们只需要排序后的原始元素列表(例如,排序后的字母数组),可以使用array_keys()函数从排序后的关联数组中提取键。

示例:

<?php
$elements = ['a', 'b', 'c', 'd', 'e'];
$values = [500, 600, 90, 120, 90];

$combinedArray = array_combine($elements, $values);
arsort($combinedArray);

// 提取排序后的键(即原始元素)
$sortedElements = array_keys($combinedArray);

echo "\n最终排序后的元素列表:\n";
print_r($sortedElements);
/*
输出:
最终排序后的元素列表:
Array
(
    [0] => b
    [1] => a
    [2] => d
    [3] => c
    [4] => e
)
*/
?>

现在,$sortedElements数组就包含了按照频率从高到低排序的字母。

完整代码示例

将上述步骤整合,形成一个完整的解决方案:

<?php
/**
 * 根据第二个数组的值对第一个数组进行排序的函数
 *
 * @param array $elements 待排序的元素数组
 * @param array $values 对应元素的排序依据值数组
 * @param bool $descending 是否按降序排序,默认为true (降序)
 * @return array 排序后的元素数组
 * @throws InvalidArgumentException 如果两个输入数组长度不一致
 */
function sortArrayByAssociatedValues(array $elements, array $values, bool $descending = true): array
{
    if (count($elements) !== count($values)) {
        throw new InvalidArgumentException("两个输入数组的长度必须一致。");
    }

    // 1. 合并数组:将元素作为键,值作为频率
    $combinedArray = array_combine($elements, $values);

    // 2. 关联排序:根据频率进行排序
    if ($descending) {
        arsort($combinedArray); // 降序
    } else {
        asort($combinedArray);  // 升序
    }

    // 3. 提取排序后的元素(键)
    return array_keys($combinedArray);
}

// 示例数据
$letters = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'];
$frequencies = [168, 118, 150, 80, 200, 70, 60, 100, 190, 20, 30, 130, 110, 140, 170, 90, 10, 180, 160, 120, 50, 40, 65, 25, 35, 15];

echo "原始字母数组:\n";
print_r($letters);
echo "原始频率数组:\n";
print_r($frequencies);

// 按频率降序排序
$sortedLettersDesc = sortArrayByAssociatedValues($letters, $frequencies, true);
echo "\n按频率降序排序后的字母:\n";
print_r($sortedLettersDesc);

// 按频率升序排序
$sortedLettersAsc = sortArrayByAssociatedValues($letters, $frequencies, false);
echo "\n按频率升序排序后的字母:\n";
print_r($sortedLettersAsc);

// 错误处理示例
try {
    sortArrayByAssociatedValues(['a', 'b'], [100]);
} catch (InvalidArgumentException $e) {
    echo "\n错误: " . $e->getMessage() . "\n";
}

?>

注意事项与总结

  1. 数组长度一致性: array_combine()函数要求作为键和值的两个数组长度必须严格一致。如果长度不一致,它将返回false并可能导致后续操作失败。在实际应用中,建议在调用前进行长度检查。
  2. 同值元素的排序: 当多个元素具有相同的关联值时(例如,'c'和'e'都为90),arsort()和asort()的相对顺序是不确定的,这取决于PHP内部的排序实现。如果需要对同值元素进行二次排序,则需要使用uasort()配合自定义比较函数。
  3. 性能考量: 对于非常大的数组,array_combine()会创建一个新的关联数组,这会占用额外的内存。然而,对于大多数常见场景,这种方法在性能和代码简洁性之间取得了很好的平衡。
  4. 键值互换: 如果你的需求是根据第一个数组的值对第二个数组进行排序,那么在array_combine()时,只需将两个数组的参数位置互换即可。

通过array_combine()和arsort()(或asort())的组合使用,PHP提供了一种优雅且高效的方式来解决根据第二个数组的值对第一个数组进行排序的问题。这种方法避免了手动编写复杂的排序算法,使代码更加简洁、易读和易于维护。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

409

2023.09.04

treenode的用法
treenode的用法

​在计算机编程领域,TreeNode是一种常见的数据结构,通常用于构建树形结构。在不同的编程语言中,TreeNode可能有不同的实现方式和用法,通常用于表示树的节点信息。更多关于treenode相关问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

550

2023.12.01

C++ 高效算法与数据结构
C++ 高效算法与数据结构

本专题讲解 C++ 中常用算法与数据结构的实现与优化,涵盖排序算法(快速排序、归并排序)、查找算法、图算法、动态规划、贪心算法等,并结合实际案例分析如何选择最优算法来提高程序效率。通过深入理解数据结构(链表、树、堆、哈希表等),帮助开发者提升 在复杂应用中的算法设计与性能优化能力。

30

2025.12.22

深入理解算法:高效算法与数据结构专题
深入理解算法:高效算法与数据结构专题

本专题专注于算法与数据结构的核心概念,适合想深入理解并提升编程能力的开发者。专题内容包括常见数据结构的实现与应用,如数组、链表、栈、队列、哈希表、树、图等;以及高效的排序算法、搜索算法、动态规划等经典算法。通过详细的讲解与复杂度分析,帮助开发者不仅能熟练运用这些基础知识,还能在实际编程中优化性能,提高代码的执行效率。本专题适合准备面试的开发者,也适合希望提高算法思维的编程爱好者。

45

2026.01.06

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

500

2023.08.14

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

25

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

44

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

174

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

50

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.5万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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