PHP 的四种基础算法主要包括:
1、排序算法
2、查找算法
3、递归算法
4、分治算法
排序算法
排序算法主要用于对数据进行排序,比如从小到大或者从大到小,在 PHP 中,常见的排序算法有冒泡排序、选择排序、插入排序等。
冒泡排序的基本思想是:通过对待排序序列从前向后(从下标较小的元素开始),依次比较相邻元素的值,若发现逆序则交换,使值较大的元素逐渐从前移向后部,就像水底下的气泡一样逐渐向上冒。
function bubbleSort($arr){ $len = count($arr); for($i=0;$i<$len1;$i++){ for($j=$i+1;$j<$len;$j++){ if($arr[$i]>$arr[$j]){ $tmp = $arr[$i]; $arr[$i] = $arr[$j]; $arr[$j] = $tmp; } } } return $arr; }
查找算法
查找算法主要用于在数据集中查找特定的数据,在 PHP 中,常见的查找算法有线性查找和二分查找。
二分查找
二分查找是一种效率较高的查找方法,要求数据集已经按照大小顺序排列,其基本思想是:首先确定数据集的中间位置,然后将待查找的值与中间位置的值进行比较,如果相等则查找成功;如果待查找的值小于中间位置的值,则在数据集的前半部分继续查找;如果待查找的值大于中间位置的值,则在数据集的后半部分继续查找,如此循环,直到找到待查找的值,或者查找范围为空。
function binarySearch($arr, $target){ $left = 0; $right = count($arr) 1; while($left <= $right){ $mid = floor(($left + $right) / 2); if($arr[$mid] == $target){ return $mid; }else if($arr[$mid] > $target){ $right = $mid 1; }else{ $left = $mid + 1; } } return 1; }
递归算法
递归算法是一种利用函数自身调用自身来解决问题的方法,在 PHP 中,常见的递归算法有计算阶乘、斐波那契数列等。
计算阶乘
阶乘是一个正整数n的所有小于及等于n的正整数的积,记作n!,例如5!=5*4*3*2*1,使用递归的方式实现阶乘,就是当n>1时,n!=n*(n1)!。
function factorial($n){ if($n == 1){ return 1; }else{ return $n * factorial($n 1); } }
分治算法
分治算法是一种解决问题的策略,它将一个大问题分解为若干个小问题,然后分别解决这些小问题,最后将这些小问题的解合并成大问题的解,在 PHP 中,常见的分治算法有归并排序、快速排序等。
快速排序
快速排序是通过一趟排序将待排序的数据分割成独立的两部分,其中一部分的所有数据都比另一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。
function quickSort($arr){ if(count($arr)<=1){ return $arr; } $pivot = $arr[0]; $left = $right = []; foreach($arr as $k=>$v){ if($v<$pivot){ $left[] = $v; }else{ $right[] = $v; } } return array_merge(quickSort($left),[$pivot],quickSort($right)); }
原创文章,作者:未希,如若转载,请注明出处:https://www.kdun.com/ask/652013.html
本网站发布或转载的文章及图片均来自网络,其原创性以及文中表达的观点和判断不代表本网站。如有问题,请联系客服处理。
发表回复