search
HomeBackend DevelopmentPHP TutorialRecursion on the basis of PHP data structure

Recursion on the basis of PHP data structure

Jul 07, 2018 pm 03:29 PM
recursionrecursive call

This article mainly introduces the recursion on the basis of PHP data structure, which has certain reference value. Now I share it with you. Friends in need can refer to it

What is recursion?

As mentioned before, recursion is a solution that breaks down large problems into small ones. Generally speaking, recursion is called a call to the function itself. It may sound strange to say this, but in fact in recursion the function does have to call itself.

A chestnut

For example, in mathematics, we all know the concept of "factorial". For example, the factorial of 5 is 5*4*3*2*1.

  • 5! = 5 * 4!

  • 4! = 4 * 3!

  • 3! = 3 * 2!

  • 2! = 2 * 1!

  • 1! = 1 * 0!

  • 0! = 1

We can summarize the rule for finding the factorial of n, that is, n! = n * (n -1) !

This reflects recursion. You can find from this that we transformed the factorial of 5 into another small problem step by step.

Characteristics of recursive algorithms

  • Every recursive call must be based on a small sub-problem. For example, the factorial of 5 is the factorial of 5 times 4.

  • Recursion must have a Base case. For example, the base case of factorial is 0. When the condition is 0, the recursion stops.

  • Avoid loop calls during recursion, otherwise the computer will display a stack overflow error in the end.

function factorial(int $n): int
{
    if ($n = 0) {
        return 1;
    }
    
    return $n * factorial($n - 1);
}

Looking at the above code, we can see that we have a basic condition for the solution to the factorial problem, which is that when n is 0, we return 1. If this condition is not met, we return n multiplied by factorial(n), which meets the first and third items of the recursion property. We avoid looping calls because we break each recursive call into a smaller sub-problem of the larger problem. The above algorithm idea can be expressed as:

Recursion Vs iterationRecursion on the basis of PHP data structure

We can also use the iterative method to implement the above recursive code

function factorial(int $n): int
{
    $result = 1;
    
    for ($i = $n; $i > 0; $i--) {
        $result*= $n;
    }
    
    return $result;
}

If a problem can be very It's easy to use iteration to solve, why do we use recursion?

Recursion is used to deal with more complex problems. Not all problems can be solved simply using iteration. Recursion uses function calls to manage the call stack, so recursion uses more time and memory than iteration. Furthermore, in iteration, we will have a result at each step, but in recursion we have to wait until the base case execution ends before we have any result. Looking at the above example, we find that in the recursive algorithm we do not have any variables or declarations to save the results, while in the iterative algorithm we use $result to save the returned results each time.

Fibonacci Sequence

In mathematics, the Fibonacci Sequence is a special integer sequence. Each number in the sequence is generated by the sum of two other numbers. . The rules are as follows:

Recursion on the basis of PHP data structure

function fibonacci($n)
{
    if ($n == 0) {
        return 0;
    }
    
    if ($n == 1) {
        return 1;
    }
    
    return fibonacci($n - 1) + fibonacci($ - 2);
}

Greatest Common Factor

Another common problem using recursive algorithms is to find the greatest common factor of two numbers.

Recursion on the basis of PHP data structure

function gcd(int $a, int $b)
{
    if ($b == 0) {
        return $a;
    }
    
    return gcd($b, $a % $b);
}

Recursion type

  • Linear recursion

In every recursive call , the function only calls itself once, which is called linear recursion.

  • Biary recursion

In binary recursion, each recursive call to the function calls itself twice. The algorithm for solving the Fibonacci sequence is binary recursion. In addition, binary search, divide and conquer algorithm, merge sort, etc. also use binary recursion.

  • Tail recursion

When a recursion returns without waiting for operations, it is called tail recursion. In the Fibonacci algorithm, the return value needs to be multiplied by the return value of the previous recursion, so it is not tail recursive, and the algorithm for solving the greatest common factor is tail recursive. Tail recursion is a form of linear recursion.

  • Mutual recursion

For example, in each recursive call, A() calls B(), and B() calls A(). Such recursion is called mutual recursion.

  • Nested recursion

When a recursive function calls itself recursively as a parameter, it is called nested recursion. A common example is the Ackerman function, see the expression below.

Recursion on the basis of PHP data structure

#Looking at the last line, you can see that the second parameter is the recursive function itself.

Next section

The next article will use recursion to solve some problems encountered in actual development, such as building N-level classifications, building nested comments, traversing directory files, etc. .

The above is the entire content of this article. I hope it will be helpful to everyone's study. For more related content, please pay attention to the PHP Chinese website!

Related recommendations:

How to obtain the real IP address of the client in PHP

How to use Elasticsearch in PHP

The above is the detailed content of Recursion on the basis of PHP data structure. 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
PHP and Python: Different Paradigms ExplainedPHP and Python: Different Paradigms ExplainedApr 18, 2025 am 12:26 AM

PHP is mainly procedural programming, but also supports object-oriented programming (OOP); Python supports a variety of paradigms, including OOP, functional and procedural programming. PHP is suitable for web development, and Python is suitable for a variety of applications such as data analysis and machine learning.

PHP and Python: A Deep Dive into Their HistoryPHP and Python: A Deep Dive into Their HistoryApr 18, 2025 am 12:25 AM

PHP originated in 1994 and was developed by RasmusLerdorf. It was originally used to track website visitors and gradually evolved into a server-side scripting language and was widely used in web development. Python was developed by Guidovan Rossum in the late 1980s and was first released in 1991. It emphasizes code readability and simplicity, and is suitable for scientific computing, data analysis and other fields.

Choosing Between PHP and Python: A GuideChoosing Between PHP and Python: A GuideApr 18, 2025 am 12:24 AM

PHP is suitable for web development and rapid prototyping, and Python is suitable for data science and machine learning. 1.PHP is used for dynamic web development, with simple syntax and suitable for rapid development. 2. Python has concise syntax, is suitable for multiple fields, and has a strong library ecosystem.

PHP and Frameworks: Modernizing the LanguagePHP and Frameworks: Modernizing the LanguageApr 18, 2025 am 12:14 AM

PHP remains important in the modernization process because it supports a large number of websites and applications and adapts to development needs through frameworks. 1.PHP7 improves performance and introduces new features. 2. Modern frameworks such as Laravel, Symfony and CodeIgniter simplify development and improve code quality. 3. Performance optimization and best practices further improve application efficiency.

PHP's Impact: Web Development and BeyondPHP's Impact: Web Development and BeyondApr 18, 2025 am 12:10 AM

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

How does PHP type hinting work, including scalar types, return types, union types, and nullable types?How does PHP type hinting work, including scalar types, return types, union types, and nullable types?Apr 17, 2025 am 12:25 AM

PHP type prompts to improve code quality and readability. 1) Scalar type tips: Since PHP7.0, basic data types are allowed to be specified in function parameters, such as int, float, etc. 2) Return type prompt: Ensure the consistency of the function return value type. 3) Union type prompt: Since PHP8.0, multiple types are allowed to be specified in function parameters or return values. 4) Nullable type prompt: Allows to include null values ​​and handle functions that may return null values.

How does PHP handle object cloning (clone keyword) and the __clone magic method?How does PHP handle object cloning (clone keyword) and the __clone magic method?Apr 17, 2025 am 12:24 AM

In PHP, use the clone keyword to create a copy of the object and customize the cloning behavior through the \_\_clone magic method. 1. Use the clone keyword to make a shallow copy, cloning the object's properties but not the object's properties. 2. The \_\_clone method can deeply copy nested objects to avoid shallow copying problems. 3. Pay attention to avoid circular references and performance problems in cloning, and optimize cloning operations to improve efficiency.

PHP vs. Python: Use Cases and ApplicationsPHP vs. Python: Use Cases and ApplicationsApr 17, 2025 am 12:23 AM

PHP is suitable for web development and content management systems, and Python is suitable for data science, machine learning and automation scripts. 1.PHP performs well in building fast and scalable websites and applications and is commonly used in CMS such as WordPress. 2. Python has performed outstandingly in the fields of data science and machine learning, with rich libraries such as NumPy and TensorFlow.

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

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
1 months agoBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Have Crossplay?
1 months agoBy尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use