PHP面试之常见基础算法(附代码示例)
本篇文章给大家带来了关于PHP的相关知识,其中主要介绍了关于常见基础算法的相关内容,包括了斐波那契数递归法、扫描文件目录、二分查找等问题,下面根据实际代码一起来看一下,希望对大家有帮助。

推荐学习:《PHP视频教程》
前言
PHP 是世界上最好的语言,一度认为算法对于 PHPer 是多余的存在,而往往面试来讲也有略微的考察,相信大家在大多数面试情况下都会被要求写冒泡排序,然而也有部分 PHPer 连冒泡排序都写半天(比如我)
一般面试以下几种算法足以应对!!!如有错误请评论修订,谢谢!
已完成
斐波那契数列
扫描文件夹
二分查找
冒泡排序
快速排序
LeetCode 第一题
TODO
堆排序
选择排序
链表翻转
动态规划
<?php
class Algorithmic {
/***
* 斐波那契数递归法,f(n) = f(n-1) + f(n-2) 递归层级太多,调用栈爆满,100层
*/
function fib($n) {
if ($n < 2) {
return 1;
} else {
return $this->fib($n - 1) + $this->fib($n - 2);
}
}
/***
* 使用数组存储每一个fib(n)的数值,空间复杂度增加
* @param $dir
* @return array
*/
function fib2($n) {
if ($n < 2) {
return 1;
} else {
$arr = [1, 1];
for ($i = 2; $i <= $n; $i++) {
$arr[$i] = $arr[$i - 1] + $arr[$i - 2];
}
}
return $arr[$n];
}
/***
* 使用两个临时变量存储前两个值fib(n)的数值,空间复杂度增加比数组降低
* @param $dir
* @return array
*/
function fib3($n) {
if ($n < 2) {
return 1;
} else {
$last = 1; //等式第二项
$lastLast = 1; //等式第一项
for ($i = 2; $i <= $n; $i++) {
$current = $last + $lastLast;
$lastLast = $last;
$last = $current;
}
return $current;
}
}
/***
* 扫描文件目录
* @param $dir
* @return array
*/
function scanFile($dir) {
$fileList = [];
if (is_dir($dir)) {
$dh = opendir($dir);
while ($file = readdir($dh)) {
if ($file == '.' || $file == '..') continue; //linux下一切皆文件
$newDir = $dir . '/' . $file;
if (is_dir($newDir)) {
$fileList[][$file] = $this->scanFile($newDir);
} else {
$fileList[] = $file;
}
}
closedir($dh);
}
return $fileList;
}
/***
* 二分查找
*/
function binarySort($arr, $target) {
if (!is_array($arr) || count($arr) < 2) {
return $arr;
}
$len = count($arr);
$start = 0;
$end = $len - 1;
while ($start <= $end) {
$middle = floor(($start + $end) / 2) ;
if ($arr[$middle] == $target) {
return $middle;
} elseif ($arr[$middle] < $target) {
$start = $middle + 1;
} else {
$end = $middle - 1;
}
}
return false;
}
/***
* 冒泡排序
*/
function bubbleSort($arr) {
for ($i = count($arr) - 1; $i > 0; $i--) {
for ($j = 0; $j < $i; $j++) {
if ($arr[$j+1] < $arr[$j]) {
$temp = $arr[$j];
$arr[$j] = $arr[$j+1];
$arr[$j+1] = $temp;
}
}
}
return $arr;
}
/***
* 快排序
*/
function quickSort($arr) {
if (!is_array($arr) || count($arr) < 2) {
return $arr;
}
$base = $arr[0];
$left = [];
$right = [];
for ($i = 1; $i <= count($arr) - 1; $i++) {
if ($arr[$i] < $base) {
$left[] = $arr[$i];
} else {
$right[] = $arr[$i];
}
}
return array_merge(array_merge($this->quickSort($left),[$base]), $this->quickSort($right));
}
/***
* 两数之和, LeetCode第一题
* @param $arr
*/
function twoSum($arr, $sum = 8){
$tempArr = [];
foreach ($arr as $k => $v) {
if (isset($tempArr[$v])) {
return [$k, $tempArr[$v]];
}
$tempArr[$sum-$v] = $k;
}
return [];
}
}
$algorithmic = new Algorithmic();
//var_dump($algorithmic->scanFile("./"));
//var_dump($algorithmic->twoSum([4,5,3,4,5,67,787]));
//var_dump($algorithmic->fib3(4)); // 1 1 2 3 5
//var_dump($algorithmic->binarySort([1,3, 4, 5,7,9], 3)); //
var_dump($algorithmic->quickSort([14,5,13,114,4,3,167,87,14]));推荐学习:《PHP视频教程》
相关阅读 更多
-
什么是黑盒测试?有哪些常用的黑盒测试方法? 时间:2025-10-29 -
视频码率是什么意思?怎么调节好?FPS越高越好吗? 时间:2025-10-29 -
什么是子网掩码和默认网关?它们各有什么作用? 时间:2025-10-29 -
Java中System.setProperty()用法、应用场景和设置属性详解 时间:2025-10-29 -
什么是堡垒机和跳板机?两者之间有什么区别? 时间:2025-10-29 -
什么是堡垒机 堡垒机的作用功能和原理 堡垒机和防火墙的区别 时间:2025-10-29
今日更新
-
2026年加密货币投资新手必看:5大优质平台排名与指南
阅读:18
-
"皮皮虾是什么梗?揭秘网络爆火神兽的搞笑日常"
阅读:18
-
2026全球五大最稳定交易所推荐 支持法币充值交易更便捷
阅读:18
-
2026年最值得关注的加密货币:TON SOL SUI涨幅领先
阅读:18
-
键盘侠是什么梗?指网络上爱指点江山却无实际行动的网友,快来了解这一网络热词背后的真相!
阅读:18
-
2026年十大潜力公链代币:ETH、SOL、APT领跑区块链投资新趋势
阅读:18
-
什么霞是什么梗?揭秘网络热词霞的爆火真相,3秒get流行密码!
阅读:18
-
2026年最具潜力NFT与GameFi代币TOP10榜单
阅读:18
-
2026年全球加密货币市值排名:比特币BTC稳居榜首
阅读:18
-
"什么下笔是什么梗"解析:网络热词出处及爆火原因揭秘,看完秒懂!
阅读:18










