使用珠算法对PHP数组进行排序
首先给大家简单介绍下什么是珠算法?
珠算法也叫珠排序,是一种自然排序算法,由Joshua J. Arulanandham, Cristian S. Calude 和 Michael J. Dinneen 在2002年发展而来,并且在欧洲理论计算机协会(European Association for Theoretical Computer Science,简称EATCS)的新闻简报上发表了该算法。
珠排序的数字和模拟硬件实现都可以实现 O(n );但是,该算法的实现在软件中往往要慢得多,只能用于对正整数列表进行排序。
在简单了解该算法之后,我们直接上代码:
<?php function columns($uarr) { $n=$uarr; if (count($n) == 0) return array(); else if (count($n) == 1) return array_chunk($n[0], 1); array_unshift($uarr, NULL); $transpose = call_user_func_array('array_map', $uarr); return array_map('array_filter', $transpose); } function bead_sort($uarr) { foreach ($uarr as $e) $poles []= array_fill(0, $e, 1); return array_map('count', columns(columns($poles))); } echo '原始数组: '.' '; var_dump(array(5,3,1,3,8,7,4,1,1,3)); echo ' '.'珠排序后 : '.' '; var_dump(bead_sort(array(5,3,1,3,8,7,4,1,1,3)));
运行结果如:
在上述代码中给大家介绍几个关键的函数:
1、array_unshift()
函数:用于向数组插入新元素。新数组的值将被插入到数组的开头。被加上的元素作为一个整体添加,这些元素在数组中的顺序和在参数中的顺序一样。该函数会返回数组中元素的个数。
2、c
all_user_func_array
:调用回调函数,并把一个数组参数作为回调函数的参数,语法是“call_user_func_array(callable $callback, array $param_arr): mixed
”,表示把第一个参数作为回调函数(callback)调用,把参数数组作(param_arr)为回调函数的的参数传入。
3、array_map
:为数组的每个元素应用回调函数。
最后给大家推荐一个咱们平台的最新免费课程《从0开始进入PHP的世界》~快来学习吧!
-
nrg是什么格式文件?nrg文件用什么打开? 时间:2025-09-10
-
JavaScript中removeChild删除所有子节点方法详解(附代码) 时间:2025-09-10
-
Java运行时异常(RuntimeException)的原因及解决办法 时间:2025-09-10
-
PHP中随机数生成的方法有哪些(生成随机数的函数) 时间:2025-09-10
-
Java ExceptionInInitializerError异常的原因及对应解决办法 时间:2025-09-10
-
Linux常用命令awk的用法 grep、awk、sed三者的区别 时间:2025-09-09
今日更新
-
童年的梗是什么梗?揭秘80、90后集体回忆杀,一秒带你重回快乐时光!
阅读:18
-
童年梗是什么梗?揭秘网络怀旧热潮背后原因,带你重温经典回忆杀!
阅读:18
-
童年时候的梗是什么梗?揭秘那些年让你笑到肚疼的经典回忆!
阅读:18
-
童七七是什么梗揭秘:全网爆火的可爱暗号,00后都在用的社交新潮流!
阅读:18
-
童真是什么梗?揭秘网络热词背后的纯真与幽默,一秒get快乐源泉!
阅读:18
-
瞳孔地震是什么梗?揭秘网络热词背后的爆笑瞬间!
阅读:18
-
统一六国的梗是什么梗?揭秘秦始皇爆笑网络热梗背后的真相!
阅读:18
-
捅西瓜梗是网络流行语,源自搞笑视频中夸张捅西瓜动作,暗指用极端方式解决问题,幽默又带讽刺意味。
阅读:18
-
怪兽八号手游核爆配队详解-适用所有主C
阅读:18
-
逆水寒手游十月版本前瞻-航母联动特色逆水杀曝光
阅读:18