首頁 >後端開發 >php教程 >PHP實作各種經典演算法

PHP實作各種經典演算法

WBOY
WBOY原創
2016-07-29 09:01:031007瀏覽
  
//--------------------  
// 基本資料結構演算法 
//-------- ------------  
//二分查找(在陣列中尋找某一元素)  
function bin_sch($array,  $ ( $low 
        $mid =  intval(($low+$   $k){   
            return $mid ;   
        }elseif ( $k   $mid-1, $k);   
        }else{    
🠜  ($array, $mid+ 1, $high, $k);   
        }      
}   
//順序尋找(在陣列中尋找某一元素)  
function  seq_sch($array, $n,  $k){   
    $array[$n]  _$k n; $i++){   
        if( $array[$i]==$k){   
          
    }   
    if ($i  }else{   
        return -1;   
    }    
function delete_array_element($array , $i)  
{  
        $len =  count($array);   
                     $array[$j] = $array [$j+1 ];  
        }  
           
}

//冒泡排序(陣列排序)  
function bubble_sort( $array)  
{  🠎 
{  🠎🠎); 
        if ($count 
        for($i=0 ; $i >$i; $j--){  
$array[$j];  
                          ];  
                                                 }  
        }  
        返回$array;  
}  
//快速排序(隊列排序)  
function quick_sort($array ) {  
        if        $key = $array [0];  
        $left_arr  = array() ;  
        $right_arr = array();  
   
                if ($array[ $i] 

                         $left_arr [com  其他  
                          }  
        $left_arr = quick_sort($left_arr );
        $right_arr = quick_sort( $right_arr);  
    }

//------------------------  
// PHP內建字串函數實現  
//----- -------------------  
//字串長度  
function strlen ($str)  
{  ' ) return 0;  
        $count =  0;  
🎠             if ( $str[$count] != NULL){  
       
                        continue;       continue;  
                }else{  
                        break;  
                }  
        }  
        return $count;  
}  
//截取子串  
function substr($str, $start,  $length =NULL)  
{  
        if ($str== '' || $1 $length!=NULL) && ( $start>0) && ($length> strlen($str)-$start)) return;  
        if (( $length! ) return;  
        if ($length ==  NULL) $length = (strlen ); 
        if ($start       (strlen( $str)+$start); $i       $str[$i];  
                }  
        }  
        if ($length   for ($i= $start; $i         i];  
                }  
    

        if ( $length 
      ngth); $i++) {  
                       $i];  
                }  
        }  
        return $substr;  
}  
//字符串翻轉  
function strrev($str)  
{  
        if ($ str == '') return 0 ;  
         for ($i=(strlen($str)- 1); $.      $rev_str .= $str[$ i ];  
        }  
        return 
函數strcmp($s1,  $s2)  
{  
        s1) 
        if (strlen($s1) >   ($i =0; $i
                if ($s1[ $i] ==               繼續使用;  
        續;                返回false;  
                        }  
        返回0;  
str, $substr)  
{  
         $m = strlen($str) 
        $n = strlen($substr );  
         ($i=0; $i 

                $sub = substr($str,    if ( strcmp($sub, $substr) ==  0)  return $i;  
         false;  
}

//字串替換  
function str_replace($substr , $newsubstr, $str)  
$str);  
        $n = strlen($substr ) ;  
        $x = strlen($newsubstr );  
   );  
        for ( $i=0; $i

                          $str = str_delete ($str, $i, $n);  
       str_insert($str,  $i, $newstr);  
        }  
  //------------------ --  
// 自實作字串處理函數 
//--------------------  
//插入一段字串  

//插入一段字串  
function str_insert($str, $i , $substr)  
{  
                     $startstr .= $str[$j ];  
        }  
        for              $laststr .= $str[$j ];  
        }
        $str = ($startstr . $substr  . $laststr);  🎠 
//刪除一段字串  
function str_delete($str , $i, $ j)  
{  
        for ( $c=0; $c
        }  
 c=( $i+$j); $c

                  }  
         $str = ($startstr . $laststr );  
        return $str;  
}      
{  
        if (strlen($s1)= =NULL || !isset( $s2)) return;  
        for ($i=0         $s2[] = $s1 [$i] ;  
        }  
        return $s2 

//連接字串  
function strcat($s1 , $s2)  
{  𠟠🠎)$15705( ( $s2)) return;  
        $ newstr = $s1 ;  
        for($i=0; $i         }  
        return $newsstr;  
}  
//簡單編碼函數(與php_decode  
        if ( $str=='' && strlen( $str)>128) return false;  
        for( $i=0; $i                 if ($c>31 && $c 106 && $c         );  
                $s .= $word;  🎠      return $s;   
}  
//簡單解碼函數(以php_encode函數對應)  
/簡單解碼函數(對應於php_encode函數)  
function
{  
        if ( $str=='' && strlen($str )> i=0; $i
                $c  = ord($word);     && $c                $c = $c+75 ;  
                $word = ch   $s .= $word ;  
        }    
  

//簡單加密函數(對應於php_decrypt)  
function php_encrypt($str)  
 'abcdefghijklmnopqrstuvwxyz1234567890';  
         $decrypt_key = 'ngzztcobmuhelpd268 if ( strlen($str) == 0) return  false;  
        for ($i=0            for ($j=0; $ j 
                  
                                                                       }  
                  )       return $enstr;  
}  
//簡單解密函數(以php_encrypt函數對應)  
)function )
{  
         $encrypt_key = 'abcdefghijklmnopqrstuvwxyz12345678990567890'; decrypt_key = 'ngzqtcobmuhelkpdawxfyivrsj2468021359';  
                for ($i=0 ;  $i              
                        if ($str[$ i] == $decrypt_key [$j]){  
                  j  
                                         }  
                    return $enstr;
}  
?> 

原地址:http://www.360doc.com/content/14/0319/16/153260150326015932603032319 以上就介紹了PHP實作各種經典演算法,包括了方面的內容,希望對PHP教程有興趣的朋友有幫助。
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn