leetcode50 power(x,n)

这篇博客介绍了两种C语言和C++实现计算x的n次幂(pow(x, n))的方法,包括对于正、负整数n的处理。然而,案例中的C语言实现可能会导致超时,而C++实现则避免了这个问题。优化的C++代码通过循环计算x的n次幂,并在n为负数时正确地计算1/x的绝对值的n次幂。这展示了如何在处理数学运算时提高效率。

实现 pow(x, n) ,即计算 x 的 n 次幂函数(即,x^n)

案例超时的C语言写法:

double myPow(double x, int n)
{
    double power = 1;
    if( n == 0)
    {   
        return 1;
    }   
    else if(n>0)
    {   
        for(int i = 0;i < n ;i++)
        {
             power = power*x;
        }
        return power;
    }   
    else if(n<0)
    {   
        for(int i = 0;i < -n ;i++)
        {
             power = power*x;
        }
        return 1/power;
    }   
   return 1.0; 
}

可以通过的C++写法

double myPow(double x, int n)
{
    double power = 1;
    if( n == 0)
    {   
        return 1;
    }   
    else if(n>0)
    {   
        for(int i = 0;i < n ;i++)
        {
             power = power*x;
        }
        return power;
    }   
    else if(n<0)
    {   
        for(int i = 0;i < -n ;i++)
        {
             power = power*x;
        }
        return 1/power;
    }   
   return 1.0; 
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值