PHP面试题:使用PHP描述快速排序算法,对象可以是一个数组?
2023-09-14 09:04:58 时间
原理:快速排序使用分治策略来把待排序数据序列分为两个子序列,具体步骤为:
(1)从数列中挑出一个元素,称该元素为“基准”。
(2)扫描一遍数列,将所有比“基准”小的元素排在基准前面,所有比“基准”大的元素排在基准后面。
(3)通过递归,将各子序列划分为更小的序列,直到把小于基准值元素的子数列和大于基准值元素的子数列排序。
//快速排序(数组排序)
function QuickSort($arr){
$num = count($arr);
$l=$r=0;
for($i=1;$i<$num;$i++){
if($arr[$i] < $arr[0]){
$left[] = $arr[$i];
$l++;
}else{
$right[] = $arr[$i];
$r++;
}
}
if($l > 1){
$left = QuickSort($left);
}
$new_arr = $left;
$new_arr[] = $arr[0];
if($r > 1){
$right = QuickSort($right);
}
for($i=0;$i<$r;$i++){
$new_arr[] = $right[$i];
}
return $new_arr;
}
相关文章
- PHP面试题整理
- 【转】2012年6月26 – PPS网络电视PHP工程师最新面试题
- 程序员找工作必备 PHP 基础面试题(二)
- 程序员找工作必备 PHP 基础面试题
- php面试题之PHP核心技术
- PHP经典面试题:如何保证缓存与数据库的双写一致性?
- php基础面试题:
- (剑指Offer)面试题3:二维数组中的查找
- 前端面试题:精灵图和base64如何选择?
- PHP面试题:你所知道的php数组相关的函数?
- PHP面试题:对于大流量的网站,您采用什么样的方法来解决访问量问题?
- PHP面试题:mysql_fetch_row() 和mysql_fetch_array之间有什么区别?
- PHP面试题:windows平台, Apache Http Server启动失败, 排错思路是什么?
- PHP面试题:单例模式,创建mysqli数据库链接的单例对象
- PHP面试题:对于用户输入一串字符串$string,要求$string中只能包含大于0的数字和英文逗号,请用正则 表达式验证,对于不符合要求的$string返回出错信息
- 面试题 05.06. 整数转换
- 面试题 17.10. 主要元素
- 一个 PHP 面试题
- SpringCloud面试题及答案
- 机器学习算法高频面试题
- 【前端面试题——vue3篇】
- 高频面试题:Spring 如何解决循环依赖?