当前位置:首页 > PHP

php 实现算法

2026-02-15 00:46:31PHP

PHP 作为一门广泛应用于 Web 开发的脚本语言,同样可以高效实现各类算法。以下是几种常见算法的 PHP 实现示例,涵盖排序、搜索、递归等场景:

php 实现算法

排序算法(快速排序)

function quickSort(array $array): array {
    if (count($array) <= 1) {
        return $array;
    }
    $pivot = $array[0];
    $left = $right = [];
    for ($i = 1; $i < count($array); $i++) {
        if ($array[$i] < $pivot) {
            $left[] = $array[$i];
        } else {
            $right[] = $array[$i];
        }
    }
    return array_merge(quickSort($left), [$pivot], quickSort($right));
}

二分查找

function binarySearch(array $sortedArray, $target): int {
    $low = 0;
    $high = count($sortedArray) - 1;
    while ($low <= $high) {
        $mid = (int)(($low + $high) / 2);
        if ($sortedArray[$mid] == $target) {
            return $mid;
        }
        if ($sortedArray[$mid] < $target) {
            $low = $mid + 1;
        } else {
            $high = $mid - 1;
        }
    }
    return -1; // 未找到
}

斐波那契数列(递归与迭代)

递归实现

function fibonacciRecursive(int $n): int {
    if ($n <= 1) {
        return $n;
    }
    return fibonacciRecursive($n - 1) + fibonacciRecursive($n - 2);
}

迭代实现

function fibonacciIterative(int $n): int {
    if ($n <= 1) {
        return $n;
    }
    $a = 0; $b = 1;
    for ($i = 2; $i <= $n; $i++) {
        $temp = $a + $b;
        $a = $b;
        $b = $temp;
    }
    return $b;
}

动态规划(背包问题)

function knapSack(int $capacity, array $weights, array $values, int $n): int {
    $dp = array_fill(0, $n + 1, array_fill(0, $capacity + 1, 0));
    for ($i = 1; $i <= $n; $i++) {
        for ($w = 1; $w <= $capacity; $w++) {
            if ($weights[$i - 1] <= $w) {
                $dp[$i][$w] = max(
                    $values[$i - 1] + $dp[$i - 1][$w - $weights[$i - 1]],
                    $dp[$i - 1][$w]
                );
            } else {
                $dp[$i][$w] = $dp[$i - 1][$w];
            }
        }
    }
    return $dp[$n][$capacity];
}

注意事项

  1. 性能优化:递归算法可能因调用栈过深导致性能问题,可改用迭代或尾递归优化。
  2. 内置函数:PHP 提供 sort()array_search() 等内置函数,但自定义算法更灵活。
  3. 大数据处理:算法复杂度需结合数据规模选择(如避免 O(n²) 排序处理百万级数据)。

通过上述示例,可以扩展实现更复杂的算法(如图算法、字符串匹配等)。PHP 的数组和对象操作能力为算法实现提供了便利。

php 实现算法

标签: 算法php
分享给朋友:

相关文章

php实现文件下载

php实现文件下载

PHP 实现文件下载的方法 使用 header() 函数强制下载 设置正确的 HTTP 头信息,强制浏览器下载文件而不是直接打开。 $file = 'path/to/file.pdf'; if (…

php实现购物车

php实现购物车

PHP实现购物车功能 购物车功能是电商网站的核心模块之一,通常涉及商品添加、删除、数量修改和结算等操作。以下是使用PHP实现购物车功能的几种方法。 使用Session存储购物车数据 Session是…

php实现队列

php实现队列

PHP实现队列的方法 队列是一种先进先出(FIFO)的数据结构,PHP可以通过多种方式实现队列功能。 使用数组模拟队列 PHP数组可以模拟队列的基本操作,通过array_push和array_sh…

php验证码实现

php验证码实现

验证码实现方法 在PHP中实现验证码功能通常涉及生成随机字符串或数字,将其转换为图像,并通过会话(Session)进行验证。以下是几种常见的实现方式: 使用GD库生成图像验证码 GD库是PHP内置的…

php 实现购物车

php 实现购物车

PHP 实现购物车功能 购物车功能是电子商务网站的核心部分,可以通过 PHP 和 Session 或数据库来实现。以下是两种常见的实现方式: 使用 Session 存储购物车数据 Sessi…

php实现mysql

php实现mysql

PHP 连接 MySQL 的基本方法 PHP 提供了多种方式与 MySQL 数据库进行交互,以下是最常用的几种方法。 使用 MySQLi 扩展 MySQLi 是 MySQL 的改进扩展,支持面向对…