php经典算法实例分析

//-------------------- 
// 基本数据结构算法
//-------------------- 
//二分查找(数组里查找某个元素) 
function  bin_sch( $array ,   $low $high $k ){  
     if  $low  <=  $high ){  
         $mid  =   intval (( $low + $high )/2 );  
         if  ( $array [ $mid ] ==   $k ){  
             return  $mid ;  
         } elseif  $k  $array [ $mid ]){  
             return   bin_sch( $array $low ,   $mid -1,  $k );  
         } else {  
             return   bin_sch( $array $mid + 1,  $high $k );  
         }  
     }  
     return  -1;  
}  
//顺序查找(数组里查找某个元素) 
function   seq_sch( $array $n ,   $k ){  
     $array [ $n ] =   $k ;  
     for ( $i =0;   $i < $n $i ++){  
         if $array [ $i ]== $k ){  
             break ;  
         }  
     }  
     if  ( $i < $n ){  
         return   $i ;  
     } else {  
         return  -1;  
     }  
}  
//线性表的删除(数组中实现) 
function  delete_array_element( $array  $i
         $len  =   count ( $array );  
         for  ( $j $i $j < $len $j  ++){ 
                 $array [ $j ] =  $array  [ $j +1]; 
        
         array_pop  ( $array ); 
         return  $array 
//冒泡排序(数组排序) 
function  bubble_sort(  $array
         $count  count $array ); 
         if  ( $count  <= 0 )  return  false; 
         for ( $i =0 ;  $i < $count $i  ++){ 
                 for ( $j = $count -1 ;  $j > $i $j --){ 
                         if  ( $array [ $j ] <  $array  [ $j -1]){ 
                                  $tmp  $array [ $j ]; 
                                  $array [ $j ] =  $array $j -1]; 
                                 $array  [ $j -1] =  $tmp
                        
                
        
         return  $array
//快速排序(数组排序) 
function  quick_sort( $array  ) { 
         if  ( count ( $array ) <= 1)  return   $array
         $key  $array  [0]; 
         $left_arr   array (); 
         $right_arr  array (); 
         for  ( $i = 1;  $i < count ( $array  );  $i ++){ 
                 if  ( $array $i ] <=  $key
                         $left_arr  [] =  $array [ $i ]; 
                 else 
                          $right_arr [] =  $array [ $i  ]; 
        
         $left_arr  = quick_sort( $left_arr  ); 
         $right_arr  = quick_sort(  $right_arr ); 
         return  array_merge ( $left_arr  array ( $key ),  $right_arr ); 
 
//------------------------ 
// PHP内置字符串函数实现 
//------------------------ 
//字符串长度 
function  strlen  ( $str
         if  ( $str  ==  ''  return  0; 
         $count  =  0; 
         while  (1){ 
                 if  $str [ $count ] != NULL){ 
                          $count ++; 
                         continue
                 } else
                         break
                
        
         return  $count
//截取子串 
function  substr ( $str $start ,   $length =NULL) 
         if  ( $str ==  ''  ||  $start > strlen ( $str  ))  return
         if  (( $length !=NULL) && (  $start >0) && ( $length strlen ( $str )- $start ))  return
         if  ((  $length !=NULL) && ( $start < 0) && ( $length > strlen ( $str  )+ $start ))  return
         if  ( $length  ==  NULL)  $length  = ( strlen ( $str  ) -  $start ); 
           
         if  ( $start  <  0){ 
                 for  ( $i =( strlen $str )+ $start );  $i <( strlen  ( $str )+ $start + $length  );  $i ++) { 
                         $substr  .=   $str [ $i ]; 
                
        
         if  ( $length   > 0){ 
                 for  ( $i $start $i <( $start + $length  );  $i ++) { 
                         $substr   .=  $str [ $i ]; 
                
        
         if  $length  < 0){ 
                 for  ( $i  = $start $i <( strlen $str )+ $length );  $i ++) { 
                         $substr  .=  $str [ $i  ]; 
                
        
         return  $substr
//字符串翻转 
function  strrev ( $str
         if  ( $str  ==  '' return  0 ; 
         for  ( $i =( strlen ( $str )- 1);  $i >=0;  $i  --){ 
                 $rev_str  .=  $str [ $i  ]; 
        
         return  $rev_str
 
//字符串比较 
function  strcmp ( $s1 ,   $s2
         if  ( strlen ( $s1 ) <   strlen ( $s2 ))  return  -1 ; 
         if  ( strlen ( $s1 ) >  strlen $s2 ))  return  1; 
         for  ( $i  =0;  $i < strlen ( $s1  );  $i ++){ 
                 if  ( $s1 $i ] ==  $s2 [ $i ]){ 
                         continue
                 } else
                         return  false; 
                
        
         return   0; 
 
//查找字符串 
function   strstr ( $str $substr
          $m  strlen ( $str ); 
         $n  strlen ( $substr  ); 
         if  ( $m  $n return  false ; 
         for  ( $i =0;  $i  <=( $m - $n +1);  $i  ++){ 
                 $sub  substr $str $i $n ); 
                 if  strcmp ( $sub $substr ) ==  0)   return  $i
        
         return  false ; 
//字符串替换 
function  str_replace ( $substr  $newsubstr $str
          $m  strlen ( $str ); 
         $n  strlen ( $substr  ); 
         $x  strlen ( $newsubstr  ); 
         if  ( strchr ( $str $substr  ) == false)  return  false; 
         for  $i =0;  $i <=( $m $n +1);  $i ++){ 
                  $i  strchr ( $str ,   $substr ); 
                 $str  = str_delete ( $str $i $n ); 
                 $str  = str_insert( $str ,   $i $newstr ); 
        
         return  $str 
 
//-------------------- 
// 自实现字符串处理函数
//-------------------- 
//插入一段字符串 
function  str_insert( $str $i  $substr
         for ( $j =0 ;  $j < $i $j  ++){ 
                 $startstr  .=  $str [ $j  ]; 
        
         for  ( $j = $i $j  < strlen ( $str );  $j  ++){ 
                 $laststr  .=  $str [ $j  ]; 
        
         $str  = ( $startstr  $substr   $laststr ); 
         return  $str 
//删除一段字符串 
function  str_delete( $str  $i $j
         for  $c =0;  $c < $i ;   $c ++){ 
                 $startstr  .=  $str  [ $c ]; 
        
         for  ( $c =(  $i + $j );  $c < strlen  ( $str );  $c ++){ 
                 $laststr   .=  $str [ $c ]; 
        
          $str  = ( $startstr  $laststr  ); 
         return  $str
//复制字符串 
function  strcpy( $s1 $s2 
         if  ( strlen ( $s1 )==NULL || !isset(  $s2 ))  return
         for  ( $i =0 ;  $i < strlen ( $s1 );   $i ++){ 
                 $s2 [] =  $s1  [ $i ]; 
        
         return  $s2
//连接字符串 
function  strcat( $s1  $s2
         if  (!isset( $s1 ) || !isset(  $s2 ))  return
         $newstr  $s1 
         for ( $i =0;  $i  < count ( $s );  $i  ++){ 
                 $newstr  .=  $st [ $i  ]; 
        
         return  $newsstr
//简单编码函数(与php_decode函数对应) 
function  php_encode( $str
         if  $str == ''  &&  strlen $str )>128)  return  false; 
         for $i =0;  $i < strlen  ( $str );  $i ++){ 
                  $c  = ord( $str [ $i  ]); 
                 if  ( $c >31 &&  $c  <107)  $c  += 20 ; 
                 if  ( $c >106 &&  $c  <127)  $c  -= 75 ; 
                 $word  chr ( $c  ); 
                 $s  .=  $word
         }  
         return  $s ;  
//简单解码函数(与php_encode函数对应) 
function  php_decode( $str
         if  $str == ''  &&  strlen ( $str  )>128)  return  false; 
         for $i =0;  $i < strlen  ( $str );  $i ++){ 
                 $c   = ord( $word ); 
                 if  $c >106 &&  $c <127 )  $c  $c -20; 
                 if  ( $c >31 &&  $c < 107)  $c  $c +75 ; 
                 $word  chr $c ); 
                 $s  .=  $word 
         }  
         return  $s ;  
//简单加密函数(与php_decrypt函数对应) 
function  php_encrypt( $str
          $encrypt_key  'abcdefghijklmnopqrstuvwxyz1234567890'
          $decrypt_key  'ngzqtcobmuhelkpdawxfyivrsj2468021359'
         if  strlen ( $str ) == 0)  return   false; 
         for  ( $i =0;   $i < strlen ( $str );  $i  ++){ 
                 for  ( $j =0;  $j  < strlen ( $encrypt_key );  $j  ++){ 
                         if  ( $str [ $i ] ==  $encrypt_key  [ $j ]){ 
                                 $enstr  .=   $decrypt_key [ $j ]; 
                                 break
                        
                
        
         return  $enstr
//简单解密函数(与php_encrypt函数对应) 
function  php_decrypt( $str
          $encrypt_key  'abcdefghijklmnopqrstuvwxyz1234567890'
          $decrypt_key  'ngzqtcobmuhelkpdawxfyivrsj2468021359'
         if  strlen ( $str ) == 0)  return   false; 
         for  ( $i =0;   $i < strlen ( $str );  $i  ++){ 
                 for  ( $j =0;  $j  < strlen ( $decrypt_key );  $j  ++){ 
                         if  ( $str [ $i ] ==  $decrypt_key  [ $j ]){ 
                                 $enstr  .=   $encrypt_key [ $j ]; 
                                 break
                        
                
        
         return  $enstr
?>

转载于:https://www.cnblogs.com/wuhuan666/p/8616492.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
这里是用PHP写的几个基础算法算法的重要性貌似对于PHP程序员不怎么重要,其实是非常重要的,经典名句:算法+数据结构=程序。作为一名真正的高级PHP程序员,我认为应该熟悉C,如果你想成为真正的程序员,请好好学C,学好数据结构与算法。这里仅仅只是几个基础算法,还有很多东东要学…… 1、首先来画个菱形玩玩,很多人学C时在书上都画过,咱们用PHP画下,画了一半。 思路:多少行for一次,然后在里面空格和星号for一次。 <?phpfor($i=0;$i<=3;$i++){ for($j=0;$j<=3-$i;$j++){ echo ' '; } for($k=0;$k<=2*$i;$k++){ echo '*'; } echo '<br/>'; } 2、冒泡排序,C里基础算法,从小到大对一组数排序。 思路:这题从小到大,第一轮排最小,第二轮排第二小,第三轮排第三小,依次类推…… <?php$arr = array(3, 2, 1);$n = count($arr); //每循环一次,就跑一趟后面的排序for($j=0; $j<$n-1; $j++) {//对后面没排好的,循环查找出最大(最小)的,进行一趟排序 for($i=$j; $i<$n-1; $i++) { if($arr[$j] > $arr[$i+1]) { $t = $arr[$j]; $arr[$j] = $arr[$i+1]; $arr[$i+1] = $t; } }}print_r($arr); 3、杨辉三角,用PHP写。 思路:每一行的第一位和最后一位是1,没有变化,中间是前排一位与左边一排的和,这种算法是用一个二维数组保存,另外有种算法用一维数组也可以实现,一行一行的输出,有兴趣去写着玩下。 11 11 2 11 3 3 11 4 6 4 11 5 10 10 5 1 <?php//每行的第一个和最后一个都为1,写了6行 for($i=0; $i<6; $i++) { $a[$i][0]=1; $a[$i][$i]=1; } //出除了第一位和最后一位的值,保存在数组中 for($i=2; $i<6; $i++) { for($j=1; $j<$i; $j++) { $a[$i][$j] = $a[$i-1][$j-1]+$a[$i-1][$j]; } } //打印 for($i=0; $i<6; $i++){ for($j=0; $j<=$i; $j++) { echo $a[$i][$j].' '; } echo '<br/>'; } 4、在一组数中,要求插入一个数,按其原来顺序插入,维护原来排序方式。 思路:找到比要插入数大的那个位置,替换,然后把后面的数后移一位。 <?php$in = 2;$arr = array(1,1,1,3,5,7);$n = count($arr);//如果要插入的数已经最大,直接打印if($arr[$n-1] < $in) { $arr[$n+1] = $in; print_r($arr); } for($i=0; $i<$n; $i++) {//找出要插入的位置 if($arr[$i] >= $in){ $t1= $arr[$i]; $arr[$i] = $in;//把后面的数据后移一位 for($j=$i+1; $j<$n+1; $j++) { $t2 = $arr[$j]; $arr[$j] = $t1; $t1 = $t2; }//打印 print_r($arr); die; }} 5、对一组数进行排序(快速排序算法)。 思路:通过一趟排序分成两部分,然后递归对这两部分排序,最后合并。 <?phpfunction q($array) { if (count($array) <= 1) {return $array;}//以$key为界,分成两个子数组 $key = $array[0]; $l = array(); $r = array(); //分别进行递归排序,然后合成一个数组 for ($i=1; $i<count($array); $i++) { if ($array[$i] <= $key) { $l[] = $array[$i]; } else { $r[] = $array[$i]; } } $l = q($l); $r = q($r); return array_merge($l, array($key), $r);} $arr = array(1,2,44,3,4,33);print_r( q($arr) ); 6、在一个数组查找你所需元素(二分查找算法)。 思路:以数组中某个值为界,再递归进行查找,直到结束。 <?phpfunction find($array, $low, $high, $k){ if ($low <= $high){ $mid = intval(($low+$high)/2); if ($array[$mid] == $k){ return $mid; }elseif ($k < $array[$mid]){ return find($array, $low, $mid-1, $k); }else{ return find($array, $mid+1, $high, $k); } } die('Not have...');} //test$array = array(2,4,3,5);$n = count($array);$r = find($array,0,$n, 7、合并多个数组,不用array_merge(),题目来于论坛。 思路:遍历每个数组,重新组成一个新数组。 <?phpfunction t(){ $c = func_num_args()-1; $a = func_get_args(); //print_r($a); for($i=0; $i<=$c; $i++){ if(is_array($a[$i])){ for($j=0; $j<count($a[$i]); $j++){ $r[] = $a[$i][$j]; } } else { die('Not a array!'); } } return $r;} //testprint_r(t(range(1,4),range(1,4),range(1,4)));echo '<br/>';$a = array_merge(range(1,4),range(1,4),range(1,4));print_r($a); 8、牛年求牛:有一母牛,到4岁可生育,每年一头,所生均是一样的母牛,到15岁绝育,不再能生,20岁死亡,问n年后有多少头牛。(来自论坛) <?phpfunction t($n) { static $num = 1 for($j=1; $j<=$n; $j++){ if($j>=4 && $j<15) {$num++;t($n-$j);} if($j==20){$num--;} } return $num;} //testecho t(8); 这里是用PHP写的几个基础算法算法的重要性貌似对于PHP程序员不怎么重要,其实是非常重要的,经典名句:算法+数据结构=程序。作为一名真正的高级PHP程序员,我认为应该熟悉C,如果你想成为真正的程序员,请好好学C,学好数据结构与算法。这里仅仅只是几个基础算法,还有很多东东要学…… 1、首先来画个菱形玩玩,很多人学C时在书上都画过,咱们用PHP画下,画了一半。 思路:多少行for一次,然后在里面空格和星号for一次。 <?phpfor($i=0;$i<=3;$i++){ for($j=0;$j<=3-$i;$j++){ echo ' '; } for($k=0;$k<=2*$i;$k++){ echo '*'; } echo '<br/>'; } 2、冒泡排序,C里基础算法,从小到大对一组数排序。 思路:这题从小到大,第一轮排最小,第二轮排第二小,第三轮排第三小,依次类推…… <?php$arr = array(3, 2, 1);$n = count($arr); //每循环一次,就跑一趟后面的排序for($j=0; $j<$n-1; $j++) {//对后面没排好的,循环查找出最大(最小)的,进行一趟排序 for($i=$j; $i<$n-1; $i++) { if($arr[$j] > $arr[$i+1]) { $t = $arr[$j]; $arr[$j] = $arr[$i+1]; $arr[$i+1] = $t; } }}print_r($arr); 3、杨辉三角,用PHP写。 思路:每一行的第一位和最后一位是1,没有变化,中间是前排一位与左边一排的和,这种算法是用一个二维数组保存,另外有种算法用一维数组也可以实现,一行一行的输出,有兴趣去写着玩下。 11 11 2 11 3 3 11 4 6 4 11 5 10 10 5 1 <?php//每行的第一个和最后一个都为1,写了6行 for($i=0; $i<6; $i++) { $a[$i][0]=1; $a[$i][$i]=1; } //出除了第一位和最后一位的值,保存在数组中 for($i=2; $i<6; $i++) { for($j=1; $j<$i; $j++) { $a[$i][$j] = $a[$i-1][$j-1]+$a[$i-1][$j]; } } //打印 for($i=0; $i<6; $i++){ for($j=0; $j<=$i; $j++) { echo $a[$i][$j].' '; } echo '<br/>'; } 4、在一组数中,要求插入一个数,按其原来顺序插入,维护原来排序方式。 思路:找到比要插入数大的那个位置,替换,然后把后面的数后移一位。 <?php$in = 2;$arr = array(1,1,1,3,5,7);$n = count($arr);//如果要插入的数已经最大,直接打印if($arr[$n-1] < $in) { $arr[$n+1] = $in; print_r($arr); } for($i=0; $i<$n; $i++) {//找出要插入的位置 if($arr[$i] >= $in){ $t1= $arr[$i]; $arr[$i] = $in;//把后面的数据后移一位 for($j=$i+1; $j<$n+1; $j++) { $t2 = $arr[$j]; $arr[$j] = $t1; $t1 = $t2; }//打印 print_r($arr); die; }} 5、对一组数进行排序(快速排序算法)。 思路:通过一趟排序分成两部分,然后递归对这两部分排序,最后合并。 <?phpfunction q($array) { if (count($array) <= 1) {return $array;}//以$key为界,分成两个子数组 $key = $array[0]; $l = array(); $r = array(); //分别进行递归排序,然后合成一个数组 for ($i=1; $i<count($array); $i++) { if ($array[$i] <= $key) { $l[] = $array[$i]; } else { $r[] = $array[$i]; } } $l = q($l); $r = q($r); return array_merge($l, array($key), $r);} $arr = array(1,2,44,3,4,33);print_r( q($arr) ); 6、在一个数组查找你所需元素(二分查找算法)。 思路:以数组中某个值为界,再递归进行查找,直到结束。 <?phpfunction find($array, $low, $high, $k){ if ($low <= $high){ $mid = intval(($low+$high)/2); if ($array[$mid] == $k){ return $mid; }elseif ($k < $array[$mid]){ return find($array, $low, $mid-1, $k); }else{ return find($array, $mid+1, $high, $k); } } die('Not have...');} //test$array = array(2,4,3,5);$n = count($array);$r = find($array,0,$n, 7、合并多个数组,不用array_merge(),题目来于论坛。 思路:遍历每个数组,重新组成一个新数组。 <?phpfunction t(){ $c = func_num_args()-1; $a = func_get_args(); //print_r($a); for($i=0; $i<=$c; $i++){ if(is_array($a[$i])){ for($j=0; $j<count($a[$i]); $j++){ $r[] = $a[$i][$j]; } } else { die('Not a array!'); } } return $r;} //testprint_r(t(range(1,4),range(1,4),range(1,4)));echo '<br/>';$a = array_merge(range(1,4),range(1,4),range(1,4));print_r($a); 8、牛年求牛:有一母牛,到4岁可生育,每年一头,所生均是一样的母牛,到15岁绝育,不再能生,20岁死亡,问n年后有多少头牛。(来自论坛) <?phpfunction t($n) { static $num = 1 for($j=1; $j<=$n; $j++){ if($j>=4 && $j<15) {$num++;t($n-$j);} if($j==20){$num--;} } return $num;} //testecho t(8);

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值