Factorial is denoted by the exclamation mark (!). We can define it as the product of all positive integers less than or equal to that number & greater than 0. For example, the factorial of 4 (4!) means 4 x 3 x 2 x 1, which equals 24. This blog post will explore how to write a Python program to find or calculate the factorial of a number efficiently.
We begin with a basic understanding of the factorial algorithm and how to calculate it in mathematics. Next, we show you different approaches to writing Python programs to find the factorial of a number using For Loop, While Loop, Functions, and Recursion.
The math or mathematical module in the Python programming language has a factorial() function that directly calculates and returns the results for any positive number. You can use this function by importing the math library.
Python Program to find the factorial of a Number using math function
The Mathematical Representation of the Factorial of n is represented as n!. Where n! = n * (n-1) * (n -2) * …….* 1. For instance, consider n = 5.
- 5! = 5 * (5 – 1) * (5 – 2) * (5 – 3) * (5 – 1)
- 5! = 5 x 4 x 3 x 2 x 1 = 120
It is denoted with the exclamation mark (!), and in this Python program code, we use the built-in math module factorial function on the number to find it.
import math a = int(input(" Please enter any Integer : ")) ft = math.factorial(a) print("The Result of %d = %d" %(a, ft))
In this program example, we use the Python math prod() function that accepts the iteration value, finds the product of each value, and returns the factorial of a number.
import math num = int(input("Enter any Number : ")) if num < 0: print("Please Enter Positive Integer Only.") elif num == 0: print("The Fact of 0 = 1.") else: fact = math.prod(range(1, num + 1)) print(f"The Fact of {num} is {fact}.")
Python Program to find the Factorial of a Number using For Loop
This code allows the user to enter any integer. Using this given value, this Python program finds the Factorial of a number using For Loop. The for loop will start from 1 and multiply the current value by the next integer until it reaches the user given number.
number = int(input(" Please enter any Number : ")) fact = 1 for i in range(1, number + 1): fact = fact * i print("The factorial of %d = %d" %(number, fact))
The user entered integer in the above program example is 4. Please refer to math functions, For Loop, While Loop, and Functions articles in Python.
First Iteration
i = 1, Fact = 1 and number = 5
Fact = Fact * i;
Fact = 1 * 1 = 1
2nd Iteration: i = 2, Fact = 1 and Number = 5
Fact = 1 * 2 = 2
3rd Iteration: i = 3, Fact = 2 and Number = 5
Fact = 2 * 3 = 6
4th Iteration: i = 4, Fact = 6 and Number = 5
Fact = 6 * 4 = 24
Next, i become 5. So, For loop Terminated.
The For Loop Time Complexity is O(n), and Space Complexity is O(1)
The above code for the factorial program in Python returns 1 for the negative values. So, we need the If else statement to print a message for negative input.
num = int(input("Enter any Number : ")) fact = 1 if num < 0: print("Please Enter Positive Integer Only.") else: for i in range(1, num + 1): fact = fact * i print("The factorial of %d = %d" %(num, fact))
Enter any Number : -9
Please Enter Positive Integer Only.
Enter any Number : 6
The factorial of 6 = 720
Python Program to find the Factorial of a Number using while Loop
In this program, we just replaced the for loop with the while Loop to find the factorial of a number.
value = int(input(" Please enter any Value : ")) fact = 1 i = 1 while(i <= value): fact = fact * i i = i + 1 print("The Result of %d = %d" %(value, fact))
Python Program to find the Factorial of a Number using Functions
This code is the same as the first example. However, we separated the factorial logic using the Functions.
def calculating(num): faco = 1 for i in range(1, num + 1): faco = faco * i return faco val = int(input(" Please enter any Value : ")) faco = calculating(val) print("The Result of %d = %d" %(val, faco))
Python Program for Factorial of a Number using Recursion
This code passes the user entered value to the Function. Within this recursive function, this example program finds the factorial of a number using the recursive function or recursively.
Within the user-defined function of this program, the If Else Statement checks whether the integer is Equal to 0 or 1. If the condition is TRUE, then the function returns 1. If the condition is False, the function recursively returns Num * (Num -1).
def factFind(num): if num < 0: print("Please Enter Positive Integer Only.") elif num == 0: return 1 else: return num * factFind(num - 1) num = int(input("Enter any Num : ")) print(f"Fact of {num} is {factFind(num)}.")
User Entered Value = 6.
Fac = num * factFind (num -1);
= 6 * factFind (5)
= 6 * 5 * factFind (4)
= 6 * 5 * 4 * factFind (3)
= 6 * 5 * 4 * 3 * factFind (2)
= 6 * 5 * 4 * 3 * 2 * factFind(1)
= 6 * 5 * 4 * 3 * 2
= 720
The Recursive function Time and Space Complexity are O(n).
Factorial using List comprehension
This Program finds the Factorial of a Number using list comprehension.
num = int(input("Enter any Number : ")) if num < 0: print("Please Enter Positive Integer Only.") elif num == 0: print("The Fact of 0 = 1.") else: fact = 1 [fact := fact * i for i in range(1, num + 1)] print(f"The Fact of {num} is {fact}.")
Enter any Number : 5
The Fact of 5 is 120.
Factorial using the lambda reduce function
This Python Program for the Factorial of a Number example uses the lambda and reduce functions.
from functools import reduce num = int(input("Enter any Number : ")) if num < 0: print("Please Enter Positive Integer Only.") elif num == 0: print("The Fact of 0 = 1.") else: fact = reduce(lambda a, b: a * b, range(1, num + 1), 1) print(f"The Fact of {num} is {fact}.")
This example is the same as the above. However, it uses the lambda recursive function.
from functools import reduce def factorial(num): return reduce(lambda a, b: a * b, range(1, num + 1), 1) num = int(input("Enter any Number : ")) if num < 0: print("Please Enter Positive Integer Only.") elif num == 0: print("The Fact of 0 = 1.") else: print(f"The Fact of {num} is {factorial(num)}.")
Enter any Number : 0
The Fact of 0 = 1.