Почему x^0 = 1 наглядно

Традиционное определение для операции возведения в натуральную степень (или целую положительную) вводится примерно следующим образом:

Возведе́ние в сте́пень — арифметическая операция, первоначально определяемая как результат многократного умножения числа на себя.

На первый взгляд, это определение затруднительно обобщить для целых показателей степени меньших единицы

    ...
x^3  = x*x*x
x^2  = x*x
x^1  = x
x^0  = ?????
x^-1 = ?????
    ...

но если вспомнить, что у операции умножения есть обратная — деление, то напрашивается расширение и для отрицательных показателей степени

    ...
x^3  = x*x*x
x^-3 = 1/(x*x*x) = 1/x/x/x
    ...

следовательно

    ...
x^3  = x*x*x
x^2  = x*x
x^1  = x
x^0  = ?
x^-1 = 1/x
x^-2 = 1/x/x
x^-3 = 1/x/x/x
    ...

Но всё ещё открытым остаётся вопрос для 0: с одной стороны, на место ? напрашивается 1, но с другой, такое определение остаётся не вполне симметричным для положительных и отрицатеьных значений…

Поэтому при внимательном рассмотрении возникает вполне естественно желание слегка видоизменить и усовершенствовать исходное

    ...
x^3  = 1*x*x*x
x^2  = 1*x*x
x^1  = 1*x
x^0  = 1
x^-1 = 1/x
x^-2 = 1/x/x
x^-3 = 1/x/x/x
    ...

В таком представлении определение словно обретает стройность вкупе с полнотой:

Возведение числа X в целочисленную степень N — арифметическая операция, определяемая как результат многократного [N по модулю раз] умножения либо деления единицы на число X.

Ход мыслей

Ход мыслей

Чуть более общий случай* на языке программирования C#

static double Pow(double x, int pow, double seed = 1d)
{
    var value = seed;
    
    if (pow < 0)
        for (var i = 0; i > pow; i--) value /= x;
    else
        for (var i = 0; i < pow; i++) value *= x;
    
    return value;
}

* в общем случае зерно [seed] может быть отличным от 1

В таком виде определение легко и естественно расширяется на случай 0^0, о котором издавна ведутся жаркие споры в математическом сообществе.

Из него закономерно следует, что 0^0 = 1.

Действитено, если мы ни разу не будем умножать единицу на ноль, то в результате останется исходная 1, но если хоть раз умножим, то уже получим 0.

* Интересно, что в таком случае функция Y = 0^X графически полностью соответствует интегралу дельта-функции Дирака! Не вполне ясно, сучайное это совпадение или за ним стоят более глубокие закономерности, но набюдение заслужиает внимания.

Если хорошенько вдуматься, то строго доказать тождество X^0 = 1 невозможно, а причина в том, что мы ведь сами даём определения функциям таким образом, чтобы они обладали удобными в прикладных расчётах свойствами.

То есть при попытке доказать тождество X^0 = 1 различными методами, на самом деле мы лишь демонстрируем, что функция возведения в степень нами же определена именно таким способом, чтобы обладать теми заданными полезными свойствами, через которые и проводится само «доказательство». То есть возникает неявный замкнутый круг.

На вопрос:

  • Почему X^0 = 1?

Честный ответ таков:

Тут уместно спросить:

На что приемлем ответ:

  • Потому что оно во многом стройное (смотреть иллюстрации выше) и обладает рядом замечательных свойств, очень уместных в практических вычислениях.

Если, скажем, определить X^0 иначе, то частично сломается свойство умножения степеней с одинаковыми основаниями X^M * X^N = X^(M+N) (а именноX^0 * X^N = X^N), что будет лишь усложнять вычисления без какой-либо смысловой ценности.

Аналогичным образом легко рассмотреть функцию целочисленного умножения через сложение и вычитание с нулевым зерном

    ...
x*3  = 0 + x + x + x
x*2  = 0 + x + x
x*1  = 0 + x
x*0  = 0
x*-1 = 0 - x
x*-2 = 0 - x - x
x*-3 = 0 - x - x - x
    ...
static double Mul(double x, int scale, double seed = 0d)
{
    var value = seed;
    
    if (pow < 0)
        for (var i = 0; i > scale; i--) value -= x;
    else
        for (var i = 0; i < scale; i++) value += x;
    
    return value;
}

Умножение произвоного числа X на целое число N — арифметическая операция, определяемая как результат многократного [N по модулю раз] сложения либо вычитания нуля с числом X.

Из определения органично вытекает тождество X*0 = 0.

В самом деле, если к нулю ничего не прибавлять и ничего из нуля не вычитать, то 0 в итоге и останется!

Похожим способом можно взглянуть на функции сложения и вычитания через функции инкремента и декремента, но в качестве зерна будет выступать уже само число.

Сложение

    ...
x +  3  = x + 1 + 1 + 1
x +  2  = x + 1 + 1
x +  1  = x + 1
x +  0  = x
x +(-1) = x - 1
x +(-2) = x - 1 - 1
x +(-3) = x - 1 - 1 - 1
    ...
static double Add(double x, int shift)
{
    var value = x;
    
    if (pow < 0)
        for (var i = 0; i > shift; i--) value -= 1;
    else
        for (var i = 0; i < shift; i++) value += 1;
    
    return value;
}

Вычитание

    ...
x -  3  = x - 1 - 1 - 1
x -  2  = x - 1 - 1
x -  1  = x - 1
x -  0  = x
x -(-1) = x + 1
x -(-2) = x + 1 + 1
x -(-3) = x + 1 + 1 + 1
    ...
static double Sub(double x, int shift)
{
    var value = x;
    
    if (pow < 0)
        for (var i = 0; i > shift; i--) value += 1;
    else
        for (var i = 0; i < shift; i++) value -= 1;
    
    return value;
}

И для полноты следует вспомнить функцию факториала и доопределить её для 0. С отрицательными аргументами становится сложнее, поскольку из общей формулы возникают бесконечные произведения, для которых традиционные методы вычислений уже во многом не определены.

n!  = 1 * [(n - 0)*(n - 1)*(n - 2)*...*3*2*1]
    ...
3!  = 1 * (3*2*1)
2!  = 1 * (2*1)
1!  = 1 * (1)
0!  = 1
    ...

Благодарю за прочтение!

Надеюсь, что рассмотренные примеры помогут читателю подружиться с тождеством X^0 = 1.

ЗЕРКАЛА СТАТЬИ

EN: gitlab, habr

RU: gitlab, habr

© Habrahabr.ru