PHP几个算法整理-PHP冒泡-PHP二分法-PHP求素数-PHP乘法表

PHP冒泡法 示例

   1. //PHP 冒泡  从小到大   
   2. function  maopao(& $arr )  
   3. {  
   4.     if (! empty empty ( $arr ))  
   5.     {  
   6.         for ( $i =0; $i < count ( $arr ); $i ++)  
   7.             {  
   8.                 if ( $arr [ $i ]> $arr [ $j ])  
   9.                 {  
  10.                     //开始交换   
  11.                     $temp  =  $arr [ $i ];  
  12.                     $arr [ $i ] =  $arr [ $j ];  
  13.                     $arr [ $j ] =  $temp ;  
  14.                 }  
  15.             }  
  16.         }  
  17.         return   $arr ;  
  18.     }  
  19. }  

//PHP冒泡  从小到大
function maopao(&$arr)
{
    if(!empty($arr))
    {
        for($i=0;$i<count($arr);$i++)
            {
                if($arr[$i]>$arr[$j])
                {
                    //开始交换
                    $temp = $arr[$i];
                    $arr[$i] = $arr[$j];
                    $arr[$j] = $temp;
                }
            }
        }
        return $arr;
    }
}

php 二分法查找 代码示例

   1. //php 二分法查找   
   2. function  erfenfa( $a , $arr )  
   3. {  
   4.     print_r($arr );  
   5.     if (! empty empty ( $a ) && ! empty empty ( $arr ))  
   6.     {  
   7.         $start  = 0;  
   8.         $end  =  count ( $arr )-1;  
   9.         $i  = 0;  
  10.         while ( $start  <=  $end )        {  
  11.                         $i  ++;  
  12.                         $step  =  floor ( $end  / 2);  
  13.                        if ( $a  ==  $arr [ $step ])  
  14.                        {  
  15.                         print_r($arr [ $step ]);  
  16.                      return   $a ;  
  17.                      }  
  18.                      if ( $a  >  $arr [ $step ])  
  19.             {  
  20.                 $start  =  $step ;  
  21.             }  
  22.   
  23.             if ( $a  <  $arr [ $step ])  
  24.             {  
  25.                 $end  =  $step ;  
  26.             }  
  27.         }  
  28.     }  
  29. }  

//php二分法查找
function erfenfa($a,$arr)
{
    print_r($arr);
    if(!empty($a) && !empty($arr))
    {
        $start = 0;
        $end = count($arr)-1;
        $i = 0;
        while($start <= $end)         {
                        $i ++;
                        $step = floor($end / 2);
                       if($a == $arr[$step])
                       {
                        print_r($arr[$step]);
                     return $a;
                     }
                     if($a > $arr[$step])
            {
                $start = $step;
            }

            if($a < $arr[$step])
            {
                $end = $step;
            }
        }
    }
}

php 求素数 – 计算 a 到 b 之间的素数。 代码示例

   1. //php 求素数  - 计算 a 到 b 之间的素数。   
   2. function  sushu( $a , $b )  
   3. {  
   4.     if (! empty empty ( $a ) && ! empty empty ( $b ))  
   5.     {  
   6.         if ( $b < $a )  return ;  
   7.         $temp  =  array ();  
   8.   
   9.         for ( $i = $a ; $i <= $b ; $i ++)  
  10.         {  
  11.             $j  =  intval (sqrt( $i ));  
  12.             $flag  = true;  
  13.             if ( $i <=3)  
  14.             {  
  15.                 $temp [ $i ] =  $i ;  
  16.             }else   
  17.             {  
  18.                 for ( $x =2; $x <= $j ; $x ++)  
  19.                 {  
  20.                     if ( $i % $x ==0)  
  21.                     {  
  22.                         $flag  = false;  
  23.                         break ;  
  24.                     }  
  25.                 }  
  26.                 if ( $flag )  
  27.                 {  
  28.                     $temp [ $i ] =  $i ;  
  29.                 }  
  30.             }  
  31.         }  
  32.         return   $temp ;  
  33.     }  
  34. }  

//php求素数  - 计算 a 到 b 之间的素数。
function sushu($a,$b)
{
    if(!empty($a) && !empty($b))
    {
        if($b<$a) return;
        $temp = array();

        for($i=$a;$i<=$b;$i++)
        {
            $j = intval(sqrt($i));
            $flag = true;
            if($i<=3)
            {
                $temp[$i] = $i;
            }else
            {
                for($x=2;$x<=$j;$x++)
                {
                    if($i%$x==0)
                    {
                        $flag = false;
                        break;
                    }
                }
                if($flag)
                {
                    $temp[$i] = $i;
                }
            }
        }
        return $temp;
    }
}

PHP输出乘法表-递归 代码示例

   1. //PHP 输出乘法表-递归   
   2. function  digui( $a , $step )  
   3. {  
   4.     if ( $a  >  $step )  return ;  
   5.     if ( ! empty empty ( $a ) && ! empty empty ( $step ) )  
   6.     {  
   7.         for ( $i =1; $i <= $a ; $i ++)  
   8.         {  
   9.             echo   $i . '*' . $a . '=' . $a * $i . "/t" ;  
  10.             if ( $i  ==  $a  )    echo   '  
  11. ' ;  
  12.         }  
  13.         $a  =  $a  + 1;  
  14.         digui($a , $step );  
  15.     }  
  16. }  

//PHP输出乘法表-递归
function digui($a,$step)
{
    if($a > $step) return;
    if( !empty($a) && !empty($step) )
    {
        for($i=1;$i<=$a;$i++)
        {
            echo $i.'*'.$a.'='.$a*$i."/t";
            if($i == $a )    echo '
';
        }
        $a = $a + 1;
        digui($a,$step);
    }
}

PHP输出乘法表-循环 代码示例

   1. //PHP 输出乘法表-循环   
   2. function  chengfa( $a , $step )  
   3. {  
   4.     if ( ! empty empty ( $a ) && ! empty empty ( $step ) )  
   5.     {  
   6.         for ( $i = $a ; $i <= $step ; $i ++)  
   7.         {  
   8.             for ( $j =1; $j <= $i ; $j ++)  
   9.             {  
  10.                 echo   $j . '*' . $i . '=' . $i * $j . "/t" ;  
  11.                 if ( $i == $j )  echo   '  
  12.  ' ;  
  13.             }  
  14.         }  
  15.     }  
  16. }

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 以下是使用 PHP 编写二分法排序的示例代码: ```php function binarySort($arr) { $count = count($arr); for ($i = 1; $i < $count; $i++) { $low = 0; $high = $i - 1; $temp = $arr[$i]; while ($low <= $high) { $mid = intval(($low + $high) / 2); if ($temp < $arr[$mid]) { $high = $mid - 1; } else { $low = $mid + 1; } } for ($j = $i - 1; $j >= $low; $j--) { $arr[$j + 1] = $arr[$j]; } $arr[$low] = $temp; } return $arr; } ``` 上面的代码实现了一个简单的二分法排序算法。它遍历了数组并使用二分法将每个元素插入到正确的位置上,以得到一个排序好的数组。 使用方法:将需要排序的数组传递给 `binarySort` 函数,它将返回一个排序好的数组。例如: ```php $arr = array(3, 6, 1, 8, 4, 9); $sortedArr = binarySort($arr); print_r($sortedArr); ``` 输出结果: ``` Array ( [0] => 1 [1] => 3 [2] => 4 [3] => 6 [4] => 8 [5] => 9 ) ``` ### 回答2: 二分法排序(二分插入排序)是一种在已经有序的数组中插入元素的一种排序算法。下面是用PHP写的一个简单的二分法排序代码: ```php function binaryInsertionSort($arr) { $length = count($arr); for ($i = 1; $i < $length; $i++) { $low = 0; $high = $i - 1; $temp = $arr[$i]; while ($low <= $high) { // 使用二分查找找到合适的插入位置 $mid = floor(($low + $high) / 2); if ($arr[$mid] > $temp) { $high = $mid - 1; } else { $low = $mid + 1; } } for ($j = $i - 1; $j >= $low; $j--) { // 将插入位置之后的元素往后移 $arr[$j + 1] = $arr[$j]; } $arr[$low] = $temp; // 将元素插入到正确的位置 } return $arr; } // 测试 $array = [5, 2, 8, 9, 1, 3]; $sortedArray = binaryInsertionSort($array); print_r($sortedArray); ``` 该代码定义了一个名为`binaryInsertionSort`的函数来进行二分法排序。在函数中,首先获取数组的长度,然后遍历数组,从索引为1的位置开始插入元素。 在每次遍历时,初始化一个`low`变量为0,一个`high`变量为$i-1,获取待插入的元素值保存在`temp`变量中。 接下来使用二分查找算法找到合适的插入位置。在每次二分查找中,计算中间位置`mid`,如果`arr[mid] > temp`,则说明待插入的元素应该在`mid`的左侧,所以`high`更新为`mid - 1`;如果`arr[mid] <= temp`,则说明待插入的元素应该在`mid`的右侧,所以`low`更新为`mid + 1`。不断更新`low`和`high`直到`low <= high`为止。 找到插入位置后,需要将插入位置后的元素往后移一位,为待插入元素腾出位置。最后,将`temp`插入到正确的位置上。 最后,我们定义了一个测试用例数组`$array`,调用`binaryInsertionSort`函数对其进行排序,并输出排序结果。 ### 回答3: 二分法排序(Binary Insertion Sort)是一种插入排序的变种,它通过将元素逐个插入有序的子数组中,来进行排序。与普通的插入排序不同的是,二分法排序使用二分查找来确定插入的位置,从而减少比较的次数。 下面是用PHP编写的二分法排序的代码: ```php function binaryInsertionSort($arr) { $len = count($arr); for($i = 1; $i < $len; $i++) { $value = $arr[$i]; $left = 0; $right = $i - 1; while ($left <= $right) { $mid = floor(($left + $right) / 2); if ($value < $arr[$mid]) { $right = $mid - 1; } else { $left = $mid + 1; } } for($j = $i - 1; $j >= $left; $j--) { $arr[$j+1] = $arr[$j]; } $arr[$left] = $value; } return $arr; } // 测试 $arr = [5, 3, 8, 2, 1, 0]; $sortedArr = binaryInsertionSort($arr); echo implode(', ', $sortedArr); ``` 以上代码中,binaryInsertionSort函数接受一个待排序的数组,并使用二分法排序算法对其进行排序。它使用循环来遍历待排序数组,通过二分查找找到插入位置,然后通过插入操作将当前元素插入到有序的子数组中。最后,返回排序好的数组。 在给定的示例中,原始数组为[5, 3, 8, 2, 1, 0],排序后的结果为[0, 1, 2, 3, 5, 8]。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值