码迷,mamicode.com
首页 > 其他好文 > 详细

p10 pow(x,n) 数值的n次方(leetcode 50)

时间:2020-03-09 17:55:26      阅读:62      评论:0      收藏:0      [点我收藏+]

标签:二分搜索   ++   搜索   bsp   思想   etc   pow   溢出   绝对值   

一:解题思路

第一种方法:这个题目首先可以想到的用一个循环,将x连续乘以n次,如果n小于0,则返回其倒数,如果n大于0,则直接返回其结果。

第二种方法:要用到二分搜索的思想在里面。

二:完整代码示例 (C++版和Java版)

第一种方法C++

  //Time:O(n),当n非常大的时候,效率不高
//Space:O(n)
  class Solution 
  {
  public:
      double myPow(double x, int n) 
      {
          double result = 1.0;

          long N = (long)abs(n);//此处将n转化为long的目的是为了防止n为整数的最小值的时候会溢出。

          for (int i = 0; i < N; i++)
          {
              result *= x;
          }

          return n<0?(1/result):(result);
      }
  };

第一种方法:Java

class Solution
{
    public double myPow(double x, int n)
    {
          double result=1.0;
          long N = Math.abs((long)n);
          
          for(int i=0;i<N;i++)
          {
              result*=x;
          }

          return n<0?(1/result):result;
    }
}

第二种方法:C++

  class Solution 
  {
  public:
      double myPow(double x, int n) 
      {
          double result = 1.0;

          long N = abs(long(n));//此处需要注意,先要将其转化为long型,然后再求其绝对值

          while (N != 0)
          {
              if (N & 1 == 1) result *= x;
              x *= x;
              N >>= 1;
          }
          
          return n < 0 ? (1 / result) : result;
      }
  };

第二种方法:Java

class Solution
{
    public double myPow(double x, int n)
    {
          double result=1.0;
          long N=Math.abs((long)n);

          while(N!=0)
          {
              if((N&1)==1) result*=x;
              x*=x;
              N>>=1;
          }

          return n<0?(1/result):(result);
    }
}

 

p10 pow(x,n) 数值的n次方(leetcode 50)

标签:二分搜索   ++   搜索   bsp   思想   etc   pow   溢出   绝对值   

原文地址:https://www.cnblogs.com/repinkply/p/12449711.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!