力扣50题 Pow(x,n)

本题是力扣网第50题。

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

采用递归和非递归思路python实现。

class Solution:
    #递归思路
    def myPow_recursion(self,x,n):
        if n == 0:                                  #递归终止条件,n==0返回1
            return 1
        if n < 0:                                   #n小于0,就返回其倒数,-n和其递归结构一致
            return 1 / self.myPow_recursion(x,-n)
        if n & 1:                                   #判断是奇数,则结果为x*(x的n-1次方)
            return x * self.myPow_recursion(x,n-1)
        else:                                       #判断是偶数,则结果是x的平方*x的n/2次方
            return self.myPow_recursion(x*x,n/2)
    #非递归思路
    def myPow_loop(self,x,n):
        if n < 0:                                   #如果n小于0,则为n变为正数,值为其倒数
            n = -n
            x = 1 / x
        pow = 1                                     #结果值初始为1
        while n:                                    #遍历循环,是n一直除以2
            if n & 1:                               #奇数时候
                pow *= x                            #pow是x
            x *= x                                  #x乘以x
            n >>= 1                                 #n连续性的除以2
        return pow
if __name__ == ‘__main__‘:
    solution = Solution()
    #(2,-1) (2,0) (2,2) (2,5)
    x,n = 2,-2
    result = solution.myPow_recursion(x,n)
    print(result)
    result = solution.myPow_loop(x,n)
    print(result)

原文地址:https://www.cnblogs.com/missidiot/p/11443404.html

时间: 2024-10-09 02:09:44

力扣50题 Pow(x,n)的相关文章

力扣算法题—042接雨水

1 #include"000库函数.h" 2 //一点头绪都没有 3 //然后就自己按自己的意思来一遍 4 //好像没有用算法 5 //16ms,让我激动一把 6 7 class Solution { 8 public: 9 int trap(vector<int>& height) { 10 if (height.size() < 2)return 0; 11 int s = 0;//起始点 12 int e = 0;//终止点 13 int v = 0;/

力扣sql题

组合两个表 表1: Person +-------------+---------+| 列名 | 类型 |+-------------+---------+| PersonId | int || FirstName | varchar || LastName | varchar |+-------------+---------+PersonId 是上表主键表2: Address +-------------+---------+| 列名 | 类型 |+-------------+-------

力扣刷题日记 2020/03/18

力扣2  两数相加 今天刷乐扣的时候发现好多人对这道题目的解法不是很理解 于是写下我自己的理解过程 共同学习! 题干 给出两个 非空 的链表用来表示两个非负的整数.其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字. 如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和. 您可以假设除了数字 0 之外,这两个数都不会以 0 开头. 已提供一个实体类: /** * Definition for singly-linked list. */ publi

力扣算法题—050计算pow(x, n)

1 #include "000库函数.h" 2 3 4 5 //使用折半算法 牛逼算法 6 class Solution { 7 public: 8 double myPow(double x, int n) { 9 if (n == 0)return 1; 10 double res = 1.0; 11 for (int i = n; i != 0; i /= 2) { 12 if (i % 2 != 0) 13 res *= x; 14 x *= x; 15 } 16 return

力扣算法题—048旋转图像

1 #include "000库函数.h" 2 3 //找位置规律 4 //先不按照规则,使用另一个矩阵 5 class Solution { 6 public: 7 void rotate(vector<vector<int>>& matrix) { 8 vector < vector<int>>v = matrix; 9 int n = matrix.size(); 10 for (int t = 0; t < 1; +

力扣算法题—062不同路径

一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为“Start” ). 机器人每次只能向下或者向右移动一步.机器人试图达到网格的右下角(在下图中标记为“Finish”). 问总共有多少条不同的路径? 例如,上图是一个7 x 3 的网格.有多少可能的路径? 说明:m 和 n 的值均不超过 100. 示例 1: 输入: m = 3, n = 2 输出: 3 解释: 从左上角开始,总共有 3 条路径可以到达右下角. 1. 向右 -> 向右 -> 向下 2. 向右 -> 向下

力扣算法题—072编辑距离

给定两个单词 word1 和 word2,计算出将 word1 转换成 word2 所使用的最少操作数 . 你可以对一个单词进行如下三种操作: 插入一个字符 删除一个字符 替换一个字符 示例 1: 输入: word1 = "horse", word2 = "ros" 输出: 3 解释: horse -> rorse (将 'h' 替换为 'r') rorse -> rose (删除 'r') rose -> ros (删除 'e') 示例 2: 输

力扣算法题—078集合

给定一组不含重复元素的整数数组 nums,返回该数组所有可能的子集(幂集). 说明:解集不能包含重复的子集. 示例: 输入: nums = [1,2,3] 输出: [ [3],   [1],   [2],   [1,2,3],   [1,3],   [2,3],   [1,2],   [] ] 1 #include "_000库函数.h" 2 3 4 //这道题就是求不同的子集问题 5 class solution { 6 public: 7 vector<vector<i

力扣算法题—085最大矩阵

给定一个仅包含 0 和 1 的二维二进制矩阵,找出只包含 1 的最大矩形,并返回其面积. 示例: 输入: [ ["1","0","1","0","0"], ["1","0","1","1","1"], ["1","1","1","1&quo