Search results
Results from the WOW.Com Content Network
A classic example of recursion is computing the factorial, which is defined recursively by 0! := 1 and n! := n × (n - 1)!.. To recursively compute its result on a given input, a recursive function calls (a copy of) itself with a different ("smaller" in some way) input and uses the result of this call to construct its result.
As an example, the function argument in the recursive expression for the factorial function below will always decrease by 1; by the well-ordering property of natural numbers, the argument will eventually reach 1 and the recursion will terminate. function factorial (argument as natural number) if argument = 0 or argument = 1 return 1 otherwise ...
Even without mechanisms to refer to the current function or calling function, anonymous recursion is possible in a language that allows functions as arguments. This is done by adding another parameter to the basic recursive function and using this parameter as the function for the recursive call.
The factorial function is a common feature in scientific calculators. [73] It is also included in scientific programming libraries such as the Python mathematical functions module [74] and the Boost C++ library. [75]
The Y combinator allows recursion to be defined as a set of rewrite rules, [21] without requiring native recursion support in the language. [22] In programming languages that support anonymous functions, fixed-point combinators allow the definition and use of anonymous recursive functions, i.e. without having to bind such functions to identifiers.
For example, the factorial function can be defined recursively by the equations 0! = 1 and, for all n > 0, n! = n(n − 1)!. Neither equation by itself constitutes a complete definition; the first is the base case, and the second is the recursive case.
A classic example of recursion is the definition of the factorial function, given here in Python code: def factorial ( n ): if n > 0 : return n * factorial ( n - 1 ) else : return 1 The function calls itself recursively on a smaller version of the input (n - 1) and multiplies the result of the recursive call by n , until reaching the base case ...
This example is artificial since this is direct recursion, so overriding the factorial method would override this function; more natural examples are when a method in a derived class calls the same method in a base class, or in cases of mutual recursion. [4] [5]