思路:分几种情况
1、不合法的输入,基数等于0并且指数小于0。
2、任何一个数的0次方都等于1。
3、指数是负数,可以先对指数求绝对值,然后计算出次方的结果之后再取倒数。
4、递归求次方效率更高,时间复杂度为O(lgn)。
根据公式:
#include<iostream>
using namespace std;
//判断浮点数是否等于0
bool equal(double d1, double d2)
{
if ((d1 - d2 < 0.000000001) && (d1 - d2 > -0.00000001))
return true;
else