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
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值