怎么用python实现一个指数运算
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,本篇内容主要讲解"怎么用python实现一个指数运算",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"怎么用python实现一个指数运算"吧!这个题目有很简单
千家信息网最后更新 2025年11月07日怎么用python实现一个指数运算
本篇内容主要讲解"怎么用python实现一个指数运算",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"怎么用python实现一个指数运算"吧!
这个题目有很简单,就是实现一个指数运算方法,但是对于递归次数和运算时间有约束。
指数运算,就是pow(x,n), x可以是浮点数,输入为x为2.000,n为10,返回1024.000;其中指数n可以为负数。
Input: 2.00000, 10
Output: 1024.00000
其实python默认内置的指数计算符号是**,比如上面就是2.000**10;直接就是用return x**n提交竟然也通过了,还比62%的时间快。
想想当然不是那么搞得,思考了下,直接一个一个乘积计算必定超过运算效率约束;可以用二分法,比如pow(x,n),如果n为偶数,可以分为pow(x,n/2)*pow(x,n/2);如果n非偶数就是多乘一次x,其他就是偶数。然后在使用缓存字典方法,避免重复计算。
在后面计算时候发现,测试系统是不会每次计算不同(x,n)都新建对象来刷新缓存字典,造成第二次的(x,n)都使用第一次的缓存字典;所以每次新的的(x,n)的时候都情况下缓存字典。
提交后,发现比87%的提交答案都快。和用python自带的n**x 对比也是快那么一些。
代码如下:
class Solution: cacheDict = {} def myRecursion(self,x,n): if n in self.cacheDict.keys(): return self.cacheDict[n] if n%2 == 1: productRe = self.myRecursion(x, (n-1)/2)*self.myRecursion(x, (n-1)/2)*x else: productRe = self.myRecursion(x, n/2)*self.myRecursion(x, n/2) self.cacheDict[n] = productRe return productRe def myPow(self, x, n) -> float: if n < 0: self.cacheDict = {0:1,1:1/x} return self.myRecursion(1.0/x, abs(n)) else: self.cacheDict = {0:1,1:x} return self.myRecursion(x, n)到此,相信大家对"怎么用python实现一个指数运算"有了更深的了解,不妨来实际操作一番吧!这里是网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
指数
运算
就是
字典
缓存
偶数
方法
内容
时候
时间
学习
不同
实用
更深
乘积
二分法
代码
兴趣
实用性
实际
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
广东数据库日志审计系统
服务器要到的舞蹈
软件开发的面板数据
数据库舰队信息系统背景
服务器发送文字
湖北弘博网络技术推广
软件开发工作太难找了
软件开发保证期一般几年
东莞网络安全建设
数据库模式导航关系图
全面战争模拟器数据库
数据库表的字段名可以包括哪些
苍穹三调数据库管理系统下载
山东dell服务器
移动 web 软件开发
chrome数据库服务器
嘉定区质量软件开发售后服务
怎么制作后台数据库
石家庄软件开发报价
ipad服务器内存不足
网络安全红方工具
用友软件开发票
单片机应用软件开发工具
网络安全周的目的
网络安全性应该选哪个
qq评论时服务器错误
机房里服务器是什么品牌的
一级数据库编码标志
应怎样实现网络安全
网络技术的概念图