php四种基础算法

PHP 的四种基础算法主要包括:

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

本网站发布或转载的文章及图片均来自网络,其原创性以及文中表达的观点和判断不代表本网站。如有问题,请联系客服处理。

(0)
未希
上一篇 2024-05-24 23:34
下一篇 2024-05-24 23:36

相关推荐

  • 冒泡排序算法实现,CodeArts Snap能自动生成代码和单元测试吗?

    冒泡排序是一种简单的排序算法,通过重复遍历要排序的列表,比较相邻元素并交换顺序错误的元素。以下是使用Python实现的冒泡排序代码及其单元测试:,,“python,def bubble_sort(arr):, n = len(arr), for i in range(n):, for j in range(0, n-i-1):, if arr[j] ˃ arr[j+1]:, arr[j], arr[j+1] = arr[j+1], arr[j], return arr,,# 单元测试,import unittest,,class TestBubbleSort(unittest.TestCase):, def test_bubble_sort(self):, self.assertEqual(bubble_sort([64, 34, 25, 12, 22, 11, 90]), [11, 12, 22, 25, 34, 64, 90]), self.assertEqual(bubble_sort([]), []), self.assertEqual(bubble_sort([1]), [1]), self.assertEqual(bubble_sort([3, 2, 1]), [1, 2, 3]),,if __name__ == ‘__main__’:, unittest.main(),“

    2024-11-25
    029
  • 如何使用CodeArts Snap生成冒泡排序的C语言代码?

    当然,以下是一段使用冒泡排序算法的C语言代码:,,“c,#include,,void bubbleSort(int arr[], int n) {, int i, j, temp;, for (i = 0; i˂ n-1; i++) {, for (j = 0; j arr[j+1]) {, temp = arr[j];, arr[j] = arr[j+1];, arr[j+1] = temp;, }, }, },},,int main() {, int arr[] = {64, 34, 25, 12, 22, 11, 90};, int n = sizeof(arr)/sizeof(arr[0]);, bubbleSort(arr, n);, printf(“Sorted array: \n”);, for (int i=0; i˂ n; i++), printf(“%d “, arr[i]);, return 0;,},“

    2024-11-16
    042
  • 如何利用CodeArts Snap智能开发助手高效生成冒泡排序代码及其单元测试?

    “python,def bubble_sort(arr):, n = len(arr), for i in range(n):, for j in range(0, ni1):, if arr[j] ˃ arr[j+1]:, arr[j], arr[j+1] = arr[j+1], arr[j],,# 单元测试,def test_bubble_sort():, arr = [64, 34, 25, 12, 22, 11, 90], bubble_sort(arr), assert arr == [11, 12, 22, 25, 34, 64, 90],,test_bubble_sort(),“,这是一个冒泡排序算法的实现,以及对应的单元测试。

    2024-10-18
    042
  • 如何利用CodeArts Snap高效生成冒泡排序的C语言代码?

    冒泡排序的C语言代码示例如下:,,“c,#include,,void bubbleSort(int arr[], int n) {, for (int i = 0; i˂ n 1; i++) {, for (int j = 0; j arr[j + 1]) {, int temp = arr[j];, arr[j] = arr[j + 1];, arr[j + 1] = temp;, }, }, },},,int main() {, int arr[] = {64, 34, 25, 12, 22, 11, 90};, int n = sizeof(arr) / sizeof(arr[0]);, bubbleSort(arr, n);, printf(“Sorted array: ,”);, for (int i = 0; i˂ n; i++) {, printf(“%d “, arr[i]);, }, return 0;,},“

    2024-10-09
    028

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注

产品购买 QQ咨询 微信咨询 SEO优化
分享本页
返回顶部
云产品限时秒杀。精选云产品高防服务器,20M大带宽限量抢购 >>点击进入