Skip to main content

Python | Recursive Function

Python - Recursive Function

Recursive function means the function call themselves within the function body until a certain condition is matched then this function is recursive function.

For example:- 

def fact(n):
     if n==0 or n==1:
          return 1
     else:
          return n*fact(n-1)

print(fact(8))

Output:-
40320

This is the example of recursive function. In this program we create a function named as fact and we call this function within the same function.
How this program works?
We give the value of n is 8 so n=8. In the first if condition, 8 is not equal to 0 and 1 so it goes to the else part in the else part the sentence is return n*fact(n-1) that means 8*fact(7) now here value of n become 7 to find fact(7) again same procedure repeat up to fact(1).  Because fact(1)=1  we give this condition. Then 
fact(2) => 2*fact(1) => 2*1=> 2  
fact(3)=> 3*fact(2) => 3*2=> 6
fact(4)=>4*fact(3)=>4*6=>24
fact(5)=>5*fact(4)=>5*24=>120
fact(6)=>6*fact(6)=>6*120=>720
fact(7)=>7*fact(6)=>7*720=>5040
fact(8)=>8*fact(7)=>8*5040=>40320

All this process done in background to find factorial using recursive. You can write this program without using recursive function. Now we will see how to write this program without using recursive function.

num = 8
fact = 1
if num == 0 or num == 1:
     print("1")
else:
     for i in range(1,num+1):
          fact = fact*i
     print(fact)
     
Output:
40320

You can see the difference of both programs. Recursive function reduce unnecessary functions. Recursive function reduce the size of program. In recursive function you must have to write if condition because they call themselves until certain condition is matched. 

We will see another example of recursive function.
1) Fibonacci series 
Ans:-

def fib(n):
     if n == 0:
          return 0
     elif n == 1:
          return 1
     else:
          return fib(n-1)+fib(n-2)
for i in range(10):
     print(fib(i))
     
Output:
0
1
1
2
3
5
8
13
21
34

There are some disadvantages of recursive function. Sometimes logic behind the recursive function is hard. Recursive function takes lot of memory and time to run. Recursive function are hard to debug. 
In the next section we will see Built in function in python. 

Prev Topic  Next Topic

Comments

Popular posts from this blog

Python | Introduction

Python is developed by Guido van Rossum . Guido van Rossum started implementing python in 1989. Python is very simple programming language so if you are new to programming, you can learn python without facing any issue. Features of Python Free and Open Source -                                                                                      Python is a open source language. We can easily install python.It is freely available at python's official website . High level language -                                                                                     ...

Python | Control Flow Tools

Control Flow Tools In this session we will see about control flow tools of python. 1) if Statement:- In the programming language if statement is important statement. Now we see how to write if statement in the python program. For Example:- >>> x = int(input("Please Enter an integer")) Please Enter an integer 50 >>> if x<0:      x=0      print("Negative change to zero") elif x==0: print("Zero") elif x==1: print("One") else: print("More") More >>>  Here is the program of if statement. You can add one or more elif part in the program. else part is the optional.      In the program we take the value of x is 50. In the if statement we write x<0 condition which is false because 50 is not less than 0 so it will go to the next part of the code which is first elif part, here we give condition x==0 this condition is also false so it will go to the second elif part which is x==1 this condition is also f...