How to resolve the algorithm Factorial step by step in the Elixir programming language
Published on 12 May 2024 09:40 PM
How to resolve the algorithm Factorial step by step in the Elixir programming language
Table of Contents
Problem Statement
Write a function to return the factorial of a number. Solutions can be iterative or recursive. Support for trapping negative n errors is optional.
Let's start with the solution:
Step by Step solution about How to resolve the algorithm Factorial step by step in the Elixir programming language
Source code in the elixir programming language
defmodule Factorial do
# Simple recursive function
def fac(0), do: 1
def fac(n) when n > 0, do: n * fac(n - 1)
# Tail recursive function
def fac_tail(0), do: 1
def fac_tail(n), do: fac_tail(n, 1)
def fac_tail(1, acc), do: acc
def fac_tail(n, acc) when n > 1, do: fac_tail(n - 1, acc * n)
# Tail recursive function with default parameter
def fac_default(n, acc \\ 1)
def fac_default(0, acc), do: acc
def fac_default(n, acc) when n > 0, do: fac_default(n - 1, acc * n)
# Using Enumeration features
def fac_reduce(0), do: 1
def fac_reduce(n) when n > 0, do: Enum.reduce(1..n, 1, &*/2)
# Using Enumeration features with pipe operator
def fac_pipe(0), do: 1
def fac_pipe(n) when n > 0, do: 1..n |> Enum.reduce(1, &*/2)
end
You may also check:How to resolve the algorithm Count in factors step by step in the Swift programming language
You may also check:How to resolve the algorithm Phrase reversals step by step in the PowerShell programming language
You may also check:How to resolve the algorithm Four bit adder step by step in the Sed programming language
You may also check:How to resolve the algorithm Harmonic series step by step in the Tcl programming language
You may also check:How to resolve the algorithm Comments step by step in the Processing programming language