search
HomeBackend DevelopmentPHP TutorialDetailed explanation of various classic algorithms implemented in PHP

Detailed explanation of various classic algorithms implemented in PHP

Apr 13, 2018 pm 04:42 PM
phpalgorithmDetailed explanation

This article mainly shares with you detailed explanations of various classic algorithms implemented in PHP. Interested friends can make a reference


    ##
    <?    
    //--------------------  
    // 基本数据结构算法 
    //--------------------  
    //二分查找(数组里查找某个元素)  
    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 == &#39;&#39; ) return 0;    
            $count =  0;    
            while (1){    
                    if ( $str[$count] != NULL){    
                             $count++;    
                            continue;    
                    }else{    
                            break;    
                    }    
            }    
            return $count;    
    }    
    //截取子串  
    function substr($str, $start,  $length=NULL)    
    {    
            if ($str== &#39;&#39; || $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 == &#39;&#39;) 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==&#39;&#39; && 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==&#39;&#39; && 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 = &#39;abcdefghijklmnopqrstuvwxyz1234567890&#39;;    
             $decrypt_key = &#39;ngzqtcobmuhelkpdawxfyivrsj2468021359&#39;;    
            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 = &#39;abcdefghijklmnopqrstuvwxyz1234567890&#39;;    
             $decrypt_key = &#39;ngzqtcobmuhelkpdawxfyivrsj2468021359&#39;;    
            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;    
    }    
    ?>
Related recommendations:

php algorithm questions

Simple PHP algorithm questions (with expansion)

php algorithm example sharing

The above is the detailed content of Detailed explanation of various classic algorithms implemented in PHP. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Dependency Injection in PHP: Avoiding Common PitfallsDependency Injection in PHP: Avoiding Common PitfallsMay 16, 2025 am 12:17 AM

DependencyInjection(DI)inPHPenhancescodeflexibilityandtestabilitybydecouplingdependencycreationfromusage.ToimplementDIeffectively:1)UseDIcontainersjudiciouslytoavoidover-engineering.2)Avoidconstructoroverloadbylimitingdependenciestothreeorfour.3)Adhe

How to Speed Up Your PHP Website: Performance TuningHow to Speed Up Your PHP Website: Performance TuningMay 16, 2025 am 12:12 AM

ToimproveyourPHPwebsite'sperformance,usethesestrategies:1)ImplementopcodecachingwithOPcachetospeedupscriptinterpretation.2)Optimizedatabasequeriesbyselectingonlynecessaryfields.3)UsecachingsystemslikeRedisorMemcachedtoreducedatabaseload.4)Applyasynch

Sending Mass Emails with PHP: Is it Possible?Sending Mass Emails with PHP: Is it Possible?May 16, 2025 am 12:10 AM

Yes,itispossibletosendmassemailswithPHP.1)UselibrarieslikePHPMailerorSwiftMailerforefficientemailsending.2)Implementdelaysbetweenemailstoavoidspamflags.3)Personalizeemailsusingdynamiccontenttoimproveengagement.4)UsequeuesystemslikeRabbitMQorRedisforb

What is the purpose of Dependency Injection in PHP?What is the purpose of Dependency Injection in PHP?May 16, 2025 am 12:10 AM

DependencyInjection(DI)inPHPisadesignpatternthatachievesInversionofControl(IoC)byallowingdependenciestobeinjectedintoclasses,enhancingmodularity,testability,andflexibility.DIdecouplesclassesfromspecificimplementations,makingcodemoremanageableandadapt

How to send an email using PHP?How to send an email using PHP?May 16, 2025 am 12:03 AM

The best ways to send emails using PHP include: 1. Use PHP's mail() function to basic sending; 2. Use PHPMailer library to send more complex HTML mail; 3. Use transactional mail services such as SendGrid to improve reliability and analysis capabilities. With these methods, you can ensure that emails not only reach the inbox, but also attract recipients.

How to calculate the total number of elements in a PHP multidimensional array?How to calculate the total number of elements in a PHP multidimensional array?May 15, 2025 pm 09:00 PM

Calculating the total number of elements in a PHP multidimensional array can be done using recursive or iterative methods. 1. The recursive method counts by traversing the array and recursively processing nested arrays. 2. The iterative method uses the stack to simulate recursion to avoid depth problems. 3. The array_walk_recursive function can also be implemented, but it requires manual counting.

What are the characteristics of do-while loops in PHP?What are the characteristics of do-while loops in PHP?May 15, 2025 pm 08:57 PM

In PHP, the characteristic of a do-while loop is to ensure that the loop body is executed at least once, and then decide whether to continue the loop based on the conditions. 1) It executes the loop body before conditional checking, suitable for scenarios where operations need to be performed at least once, such as user input verification and menu systems. 2) However, the syntax of the do-while loop can cause confusion among newbies and may add unnecessary performance overhead.

How to hash strings in PHP?How to hash strings in PHP?May 15, 2025 pm 08:54 PM

Efficient hashing strings in PHP can use the following methods: 1. Use the md5 function for fast hashing, but is not suitable for password storage. 2. Use the sha256 function to improve security. 3. Use the password_hash function to process passwords to provide the highest security and convenience.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Roblox: Bubble Gum Simulator Infinity - How To Get And Use Royal Keys
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusion System, Explained
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers Of The Witch Tree - How To Unlock The Grappling Hook
4 weeks agoBy尊渡假赌尊渡假赌尊渡假赌
Clair Obscur: Expedition 33 - How To Get Perfect Chroma Catalysts
2 weeks agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser is a secure browser environment for taking online exams securely. This software turns any computer into a secure workstation. It controls access to any utility and prevents students from using unauthorized resources.

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools