самодельный pow () c ++

Я читалКак я могу написать степенную функцию сам? и ответ, данный dan04, привлек мое внимание главным образом потому, что я не уверен в ответе, данном fortran, но я взял это и реализовал это:

#include <iostream>
using namespace std;
float pow(float base, float ex){
    // power of 0
    if (ex == 0){
        return 1;
    // negative exponenet
    }else if( ex < 0){
        return 1 / pow(base, -ex);
    // even exponenet
    }else if ((int)ex % 2 == 0){
        float half_pow = pow(base, ex/2);
        return half_pow * half_pow;
    //integer exponenet
    }else{
        return base * pow(base, ex - 1);
    }
}
int main(){
    for (int ii = 0; ii< 10; ii++){\
        cout << "pow(" << ii << ".5) = " << pow(ii, .5) << endl;
        cout << "pow(" << ii << ",2) = " << pow(ii,  2) << endl;
        cout << "pow(" << ii << ",3) = " << pow(ii,  3) << endl;
    }
}

хотя я не уверен, что я перевел это право, потому что все вызовы, дающие .5 в качестве показателя степени, возвращают 0. В ответе говорится, что может потребоваться log2 (x), основанный наa^b = 2^(b * log2(a)), но я не уверен в том, чтобы поставить это, поскольку я не уверен, где это поставить, или если я даже думаю об этом праве.

ПРИМЕЧАНИЕ: я знаю, что это может быть определено в математической библиотеке, но мне не нужны все дополнительные затраты на целую математическую библиотеку для нескольких функций.

РЕДАКТИРОВАТЬ: кто-нибудь знает реализацию с плавающей запятой для дробных показателей? (Я видел двойную реализацию, но это было использование трюка с регистрами, и мне нужна плавающая точка, и добавление библиотеки просто для выполнения трюка, мне было бы лучше просто включить библиотеку математики)

Ответы на вопрос(5)

Ваш ответ на вопрос