当前位置:首页 > PHP

php 实现算法

2026-02-15 00:46:31PHP

PHP 作为一门广泛应用于 Web 开发的脚本语言,同样可以高效实现各类算法。以下是几种常见算法的 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);
}

迭代实现

php 实现算法

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实现验证码的方法 使用GD库生成验证码 GD库是PHP中处理图像的扩展,可用于生成验证码图片。 <?php session_start(); $width = 120; $height…

php实现websocket

php实现websocket

PHP 实现 WebSocket WebSocket 是一种在单个 TCP 连接上进行全双工通信的协议。PHP 可以通过多种方式实现 WebSocket 功能,以下是几种常见的方法: 使用 Ratc…

php 登录实现

php 登录实现

PHP 登录实现 PHP 登录功能通常包括用户认证、会话管理和安全性措施。以下是实现 PHP 登录功能的关键步骤。 数据库准备 创建一个用户表存储用户信息,通常包括用户名、密码(加密存储)和其他必要…

php实现的分页

php实现的分页

PHP 实现分页的方法 基本分页逻辑 分页的核心在于计算总页数、当前页码以及数据偏移量。假设每页显示 10 条数据: $current_page = isset($_GET['page']) ? (…

php搜索功能实现的

php搜索功能实现的

PHP 搜索功能实现方法 数据库搜索实现 使用 SQL 的 LIKE 语句进行模糊匹配,适用于小型网站和简单搜索需求。 $searchTerm = $_GET['search']; $query =…

php实现一个

php实现一个

PHP 实现一个简单的计算器 创建一个基本的计算器,支持加、减、乘、除运算。以下是一个完整的实现代码示例: <?php $result = ""; if ($_SERVER["REQUES…