How do you do exponentiation in C?

前端 未结 7 1451
执笔经年
执笔经年 2020-12-05 06:31

I tried \"x = y ** e\", but that didn\'t work.

相关标签:
7条回答
  • 2020-12-05 06:46

    or you could just write the power function, with recursion as a added bonus

    int power(int x, int y){
          if(y == 0)
            return 1;
         return (x * power(x,y-1) );
        }
    

    yes,yes i know this is less effecient space and time complexity but recursion is just more fun!!

    0 讨论(0)
  • 2020-12-05 06:49

    use the pow function (it takes floats/doubles though).

    man pow:

       #include <math.h>
    
       double pow(double x, double y);
       float powf(float x, float y);
       long double powl(long double x, long double y);
    

    EDIT: For the special case of positive integer powers of 2, you can use bit shifting: (1 << x) will equal 2 to the power x. There are some potential gotchas with this, but generally, it would be correct.

    0 讨论(0)
  • 2020-12-05 06:51

    Similar to an earlier answer, this will handle positive and negative integer powers of a double nicely.

    double intpow(double a, int b)
    {
      double r = 1.0;
      if (b < 0)
      {
        a = 1.0 / a;
        b = -b;
      }
      while (b)
      {
        if (b & 1)
          r *= a;
        a *= a;
        b >>= 1;
      }
      return r;
    }
    
    0 讨论(0)
  • 2020-12-05 06:56

    The non-recursive version of the function is not too hard - here it is for integers:

    long powi(long x, unsigned n)
    {
        long p = x;
        long r = 1;
    
        while (n > 0)
        {
            if (n % 2 == 1)
                r *= p;
            p *= p;
            n /= 2;
        }
    
        return(r);
    }
    

    (Hacked out of code for raising a double value to an integer power - had to remove the code to deal with reciprocals, for example.)

    0 讨论(0)
  • 2020-12-05 07:00

    pow only works on floating-point numbers (doubles, actually). If you want to take powers of integers, and the base isn't known to be an exponent of 2, you'll have to roll your own.

    Usually the dumb way is good enough.

    int power(int base, unsigned int exp) {
        int i, result = 1;
        for (i = 0; i < exp; i++)
            result *= base;
        return result;
     }
    

    Here's a recursive solution which takes O(log n) space and time instead of the easy O(1) space O(n) time:

    int power(int base, int exp) {
        if (exp == 0)
            return 1;
        else if (exp % 2)
            return base * power(base, exp - 1);
        else {
            int temp = power(base, exp / 2);
            return temp * temp;
        }
    }
    
    0 讨论(0)
  • 2020-12-05 07:01

    To add to what Evan said: C does not have a built-in operator for exponentiation, because it is not a primitive operation for most CPUs. Thus, it's implemented as a library function.

    Also, for computing the function e^x, you can use the exp(double), expf(float), and expl(long double) functions.

    Note that you do not want to use the ^ operator, which is the bitwise exclusive OR operator.

    0 讨论(0)
提交回复
热议问题