Zero to the power of zero, denoted as, is a mathematical expression that can take different values depending on the context. In certain areas of mathematics, such as combinatorics and algebra, is conventionally defined as 1 because this assignment simplifies many formulas and ensures consistency in operations involving exponents. For instance, in combinatorics, defining aligns with the interpretation of choosing 0 elements from a set and simplifies polynomial and binomial expansions.
However, in other contexts, particularly in mathematical analysis, is often considered an indeterminate form. This is because the value of as both and approach zero can lead to different results based on the limiting process. The expression arises in limit problems and may result in a range of values or diverge to infinity, making it difficult to assign a single consistent value in these cases.
The treatment of also varies across different computer programming languages and software. While many follow the convention of assigning for practical reasons, others leave it undefined or return errors depending on the context of use, reflecting the ambiguity of the expression in mathematical analysis.
Many widely used formulas involving natural-number exponents require to be defined as . For example, the following three interpretations of make just as much sense for as they do for positive integers :
All three of these specialize to give .
When evaluating polynomials, it is convenient to define as . A (real) polynomial is an expression of the form, where is an indeterminate, and the coefficients are real numbers. Polynomials are added termwise, and multiplied by applying the distributive law and the usual rules for exponents. With these operations, polynomials form a ring . The multiplicative identity of is the polynomial ; that is, times any polynomial is just . Also, polynomials can be evaluated by specializing to a real number. More precisely, for any given real number, there is a unique unital -algebra homomorphism such that . Because is unital, . That is, for each real number, including 0. The same argument applies with replaced by any ring.
Defining is necessary for many polynomial identities. For example, the binomial theorem holds for only if .
Similarly, rings of power series require to be defined as 1 for all specializations of . For example, identities like and hold for only if .
In order for the polynomial to define a continuous function, one must define .
In calculus, the power rule is valid for at only if .
Limits involving algebraic operations can often be evaluated by replacing subexpressions with their limits; if the resulting expression does not determine the original limit, the expression is known as an indeterminate form. The expression is an indeterminate form: Given real-valued functions and approaching (as approaches a real number or) with, the limit of can be any non-negative real number or, or it can diverge, depending on and . For example, each limit below involves a function with as (a one-sided limit), but their values are different:
Thus, the two-variable function, though continuous on the set, cannot be extended to a continuous function on, no matter how one chooses to define .
On the other hand, if and are analytic functions on an open neighborhood of a number, then as approaches from any side on which is positive.This and more general results can be obtained by studying the limiting behavior of the function .[1] [2]
In the complex domain, the function may be defined for nonzero by choosing a branch of and defining as . This does not define since there is no branch of defined at, let alone in a neighborhood of .
In 1752, Euler in Introductio in analysin infinitorum wrote that and explicitly mentioned that . An annotation attributed to Mascheroni in a 1787 edition of Euler's book Institutiones calculi differentialis offered the "justification"
as well as another more involved justification. In the 1830s, Libri published several further arguments attempting to justify the claim, though these were far from convincing, even by standards of rigor at the time.
Euler, when setting, mentioned that consequently the values of the function take a "huge jump", from for, to at, to for .In 1814, Pfaff used a squeeze theorem argument to prove that as .
On the other hand, in 1821 Cauchy explained why the limit of as positive numbers and approach while being constrained by some fixed relation could be made to assume any value between and by choosing the relation appropriately. He deduced that the limit of the full two-variable function without a specified constraint is "indeterminate". With this justification, he listed along with expressions like in a table of indeterminate forms.
Apparently unaware of Cauchy's work, Möbius in 1834, building on Pfaff's argument, claimed incorrectly that whenever as approaches a number (presumably is assumed positive away from). Möbius reduced to the case, but then made the mistake of assuming that each of and could be expressed in the form for some continuous function not vanishing at and some nonnegative integer, which is true for analytic functions, but not in general. An anonymous commentator pointed out the unjustified step; then another commentator who signed his name simply as "S" provided the explicit counterexamples and as and expressed the situation by writing that " can have many different values".
There do not seem to be any authors assigning a specific value other than 1.
The IEEE 754-2008 floating-point standard is used in the design of most floating-point libraries. It recommends a number of operations for computing a power:
pown
(whose exponent is an integer) treats as ; see .pow
(whose intent is to return a non-NaN result when the exponent is an integer, like pown
) treats as .powr
treats as NaN (Not-a-Number) due to the indeterminate form; see .The pow
variant is inspired by the pow
function from C99, mainly for compatibility. It is useful mostly for languages with a single power function. The pown
and powr
variants have been introduced due to conflicting usage of the power functions and the different points of view (as stated above).
The C and C++ standards do not specify the result of (a domain error may occur). But for C, as of C99, if the normative annex F is supported, the result for real floating-point types is required to be because there are significant applications for which this value is more useful than NaN (for instance, with discrete exponents); the result on complex types is not specified, even if the informative annex G is supported. The Java standard, the .NET Framework method System.Math.Pow
, Julia, and Python also treat as . Some languages document that their exponentiation operation corresponds to the pow
function from the C mathematical library; this is the case with Lua's ^
operator and Perl's **
operator (where it is explicitly mentioned that the result of 0**0
is platform-dependent).
R, SageMath, and PARI/GP evaluate to . Mathematica simplifies to even if no constraints are placed on ; however, if is entered directly, it is treated as an error or indeterminate. Mathematica and PARI/GP further distinguish between integer and floating-point values: If the exponent is a zero of integer type, they return a of the type of the base; exponentiation with a floating-point exponent of value zero is treated as undefined, indeterminate or error.