TheAlgorithms-Ruby/maths/factorial_non_recursive_non_iterative.rb

44 lines
1 KiB
Ruby
Raw Normal View History

# A ruby program to find factorial of a given integer
# Factorial of a given integer is defined as the product of all the positive integers less than or equal to the given integer
# Mathematical representation: n! = n * (n - 1) * (n - 2) * ... * 1
#
2021-04-28 11:32:48 +02:00
# Non-recursive and non-iterative approach
#
def factorial(number)
if number < 0
2021-09-03 22:24:58 +02:00
'Please check your input number! The given number is a negative number.'
2021-04-29 03:33:20 +02:00
elsif number == 0
"The factorial of #{number} is 1."
else
2021-04-29 03:33:20 +02:00
result = (1..number).inject(:*)
"The factorial of #{number} is #{result}."
end
2021-09-03 22:24:58 +02:00
rescue StandardError
'Error: Please provide integer only!'
end
# Valid inputs
puts factorial(0)
# The factorial of 0 is 1.
puts factorial(4)
# The factorial of 4 is 24.
puts factorial(10)
# The factorial of 10 is 3628800.
puts factorial(1)
# The factorial of 1 is 1.
puts factorial(-5)
# Please check your input number! The given number is a negative number.
# Invalid inputs
2021-09-03 22:24:58 +02:00
puts factorial('a')
# Error: Please provide integer only!
2021-09-03 22:24:58 +02:00
puts factorial('2')
# Error: Please provide integer only!