PHP常用的排序和查找算法,php排序算法
本文汇总了常见的php排序算法和查找,在进行算法设计的时候有不错的借鉴价值。现分享给大家供参考之用。具体如下:
<?php /** * PHP最常用的四个排序方法及二种查找方法 * 下面的排序方法全部都通过测试 * auther : soulence * date : 2015/06/20 */ //PHP冒泡排序法 function bubbleSort(&$arr){ //这是一个中间变量 $temp=0; //我们要把数组,从小到大排序 //外层循环 $flag=false;//这个优化之后效率会很高,一般够用 for($i=0;$i<count($arr)-1;$i++){ for($j=0;$j<count($arr)-1-$i;$j++){ //说明前面的数比后面的数大,就要交换 if($arr[$j]>$arr[$j+1]){ $temp=$arr[$j]; $arr[$j]=$arr[$j+1]; $arr[$j+1]=$temp; $flag=true; } } if(!$flag){ //已经是有序了 break; } $flag=false; } } //PHP选择排序法 效率比冒泡要高 function selectSort(&$arr){ $temp=0; for($i=0;$i<count($arr)-1;$i++){ //假设$i就是最小的数 $minVal=$arr[$i]; //记录我认为的最小数的下标 $minIndex=$i; for($j=$i+1;$j<count($arr);$j++){ //说明我们认为的最小值,不是最小 if($minVal>$arr[$j]){ $minVal=$arr[$j]; $minIndex=$j; } } //最后交换 $temp=$arr[$i]; $arr[$i]=$arr[$minIndex]; $arr[$minIndex]=$temp; } } //插入排序法(小到大排序) 效率又比 选择排序法要高一些 function insertSort(&$arr){ //先默认下标为0的这个数已经是有序 for($i=1;$i<count($arr);$i++){ //$insertVal是准备插入的数 $insertVal=$arr[$i]; //准备先和谁下标为$inserIndex的比较 $inserIndex=$i-1; //如果这个条件满足,说明我们还没有找到适当的位置 while($inserIndex >= 0 && $insertVal < $arr[$inserIndex]){ //同时把数后移 $arr[$inserIndex+1] = $arr[$inserIndex]; $inserIndex--; } //插入(这时就给$inserIndex找到适当的位置) $arr[$inserIndex+1] = $insertVal; } } //快速排序法 第一种写法 不是我实现的 function quickSort($left,$right,&$arr){ $l=$left; $r=$right; $pivot= $arr[($left+$right)/2]; while($l<$r){ while($arr[$l]<$pivot){ $l++; } while($arr[$r]>$pivot){ $r--; } if($l>=$r){ break; } $temp=$arr[$l]; $arr[$l]=$arr[$r]; $arr[$r]=$temp; if($arr[$l]==$pivot){ --$r; } if($arr[$r]==$pivot){ ++$l; } } if($l==$r){ $l++; $r--; } if($left<$r) quickSort($left,$r,$arr); if($right>$l) quickSort($l,$right,$arr); } /** * 快速排序方法 第二种实现方法 自己实现的 * PHP快速排序方法 * $order asc 小到大 desc大到小 默认是asc * $order 的值只能为 asc desc 如果乱写一个值也是按asc排序的 */ function quickSort2($arr,$order = 'asc') { if(count($arr) <= 1) return $arr; $arr_left = $arr_right = array(); $val = $arr[0];unset($arr[0]); foreach ($arr as $v) { if(strtolower($order) == 'desc'){ if($v < $val) $arr_right[] = $v; else $arr_left[] = $v; }else{ if($v > $val) $arr_right[] = $v; else $arr_left[] = $v; } } $arr_left = quickSort($arr_left,$order); $arr_right = quickSort($arr_right,$order); return array_merge($arr_left,array($val),$arr_right); } //下面是查找 $arr=array(46,90,900,0,-1); //这是按顺序查询 function search(&$arr,$findVal){ $flag=false; for($i=0;$i<count($arr);$i++){ if($findVal==$arr[$i]){ echo "找到了,下标为=$i"; $flag=true; //查询一次,如果多次就不要这个 break; } } if(!$flag){ echo "查无此数"; } } //调用二分查找 $arr=array(0,90,900,99990);//注意,一定要是有序的 binarySwarch($arr,90,0,count($arr)-1); //二分查找函数,它有一个前提,查找的数组必须是有序的 function binarySearch(&$arr,$findVal,$leftIndex,$rightIndex){ //如果$rightIndex < $leftIndex条件成立,说明没有这个数,则退出 if($rightIndex < $leftIndex){ echo "找不到该数"; return; } //首先找到中间这个数 round是出于如果出现小数,四舍五入 $middleIndex=round(($rightIndex+$leftIndex)/2); //如果大于则向后面找 if($findVal > $arr[$middleIndex]){ binarySearch($arr,$findVal,$middleIndex+1,$rightIndex); //如果小于中间数,则向前面找 }else if($findVal < $arr[$middleIndex]){ binarySearch($arr,$findVal,$leftIndex,$middleIndex-1); }else{ echo "找到这个数。下标是$middleIndex"; } } ?>
希望本文所述排序算法和查找算法实例对大家的php程序设计有所帮助。

PHP仍然流行的原因是其易用性、灵活性和强大的生态系统。1)易用性和简单语法使其成为初学者的首选。2)与web开发紧密结合,处理HTTP请求和数据库交互出色。3)庞大的生态系统提供了丰富的工具和库。4)活跃的社区和开源性质使其适应新需求和技术趋势。

PHP和Python都是高层次的编程语言,广泛应用于Web开发、数据处理和自动化任务。1.PHP常用于构建动态网站和内容管理系统,而Python常用于构建Web框架和数据科学。2.PHP使用echo输出内容,Python使用print。3.两者都支持面向对象编程,但语法和关键字不同。4.PHP支持弱类型转换,Python则更严格。5.PHP性能优化包括使用OPcache和异步编程,Python则使用cProfile和异步编程。

PHP主要是过程式编程,但也支持面向对象编程(OOP);Python支持多种范式,包括OOP、函数式和过程式编程。PHP适合web开发,Python适用于多种应用,如数据分析和机器学习。

PHP起源于1994年,由RasmusLerdorf开发,最初用于跟踪网站访问者,逐渐演变为服务器端脚本语言,广泛应用于网页开发。Python由GuidovanRossum于1980年代末开发,1991年首次发布,强调代码可读性和简洁性,适用于科学计算、数据分析等领域。

PHP适合网页开发和快速原型开发,Python适用于数据科学和机器学习。1.PHP用于动态网页开发,语法简单,适合快速开发。2.Python语法简洁,适用于多领域,库生态系统强大。

PHP在现代化进程中仍然重要,因为它支持大量网站和应用,并通过框架适应开发需求。1.PHP7提升了性能并引入了新功能。2.现代框架如Laravel、Symfony和CodeIgniter简化开发,提高代码质量。3.性能优化和最佳实践进一步提升应用效率。

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

PHP类型提示提升代码质量和可读性。1)标量类型提示:自PHP7.0起,允许在函数参数中指定基本数据类型,如int、float等。2)返回类型提示:确保函数返回值类型的一致性。3)联合类型提示:自PHP8.0起,允许在函数参数或返回值中指定多个类型。4)可空类型提示:允许包含null值,处理可能返回空值的函数。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3 英文版
推荐:为Win版本,支持代码提示!

Dreamweaver Mac版
视觉化网页开发工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

EditPlus 中文破解版
体积小,语法高亮,不支持代码提示功能