Skip to main content

Recursions in Python



Learning Sections          show


Recursion in Python

Recursion in Python refers to the process where a function calls itself directly or indirectly. It is a common programming technique used for solving problems that can be broken down into smaller, similar problems.


Basic Example of Recursion

A basic example of a recursive function is calculating the factorial of a number.

# Factorial function using recursion
def factorial(n):
    if n == 0:
        return 1
    else:
        return n * factorial(n - 1)

Understanding the Recursion Flow

To understand how recursion works, consider the factorial(3) function call:

# Call stack for factorial(3)
# factorial(3) --> 3 * factorial(2)
# factorial(2) --> 2 * factorial(1)
# factorial(1) --> 1 * factorial(0)
# factorial(0) --> 1

The call stack grows until the base case is reached. After that, the results are returned and the call stack unwinds.


Benefits of Recursion

Recursion can simplify the code for problems that have a recursive structure, such as tree traversals, solving puzzles like the Tower of Hanoi, and more.


Potential Issues with Recursion

While recursion is powerful, it can also lead to issues like excessive memory usage and stack overflow if not implemented carefully. For example:

# Infinite recursion example
def infinite_recursion():
    return infinite_recursion()  # This will cause a stack overflow

Tips for Using Recursion

  • Ensure there is a base case to stop the recursion.
  • Be cautious of the maximum recursion depth in Python, which is usually 1000 by default. You can change it using sys.setrecursionlimit() if necessary.
  • Consider using memoization to optimize recursive solutions, especially for problems with overlapping subproblems.

Popular posts from this blog

MultiProcessing in Python

  Learning Sections          show MultiProcessing in Python Multiprocessing in Python involves using the multiprocessing module to run multiple processes concurrently, taking advantage of multiple CPU cores. This module provides a higher level of concurrency than threading and is especially useful for CPU-bound tasks. Creating Processes You can create and start a new process by using the multiprocessing module: import multiprocessing def print_numbers (): for i in range ( 10 ): print ( i ) p1 = multiprocessing.Process ( target = print_numbers ) p1 . start () p1 . join () # Wait for the process to complete Using Process Pools The multiprocessing module provides a Pool class, which allows you to manage a pool of worker processes: from multiprocessing import Pool def square ( n ): return n * n with Pool ( 4 ) as pool : result = pool.map ( square , range (...

Learn Python

  Learning Sections Introduction to Python Comment, escape sequence and print statement in Python Variables and Data Types in Python Typecasting in Python User input in Python String slicing and operations on string in Python String methods in Python If else conditional statements in Python Match case statement in Python For loops in Python While loops in Python Break and continue statement in Python Functions in Python Function Arguments in Python introduction to lists in Python List methods in Python Tuples in Python Operations on tuple in Python f strings in Python Docstrings in Python Recursion in Python Sets in Python Set methods in Python Dictionaries in Python for Loop with else in Python Exception Handling in Python Finally keyword in Python Raising custom errors in Python Short hand if else statements Enumerate Function in Python Virtual Environment in Python How import works in Python if __nam...

Introduction to Python Programming

  Learning Sections      show History of Python Python was created by Guido van Rossum and first released in 1991. He wanted to create a language that was easy to read and simple to use. The name "Python" comes from the British comedy series "Monty Python's Flying Circus". Key Features of Python Readability: Python's syntax is clear and easy to read. Ease of Learning: Python is straightforward, making it great for beginners. High-Level Language: Python handles much of the complexity of the computer’s operations. Interpreted Language: Python runs code line-by-line, which makes debugging easier. Dynamically Typed: You don’t need to declare variable types. Extensive Standard Library: Python has many built-in modules for various tasks. Portability: ...