怎么用python实现一个指数运算
发表于:2025-01-16 作者:千家信息网编辑
千家信息网最后更新 2025年01月16日,本篇内容主要讲解"怎么用python实现一个指数运算",感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习"怎么用python实现一个指数运算"吧!这个题目有很简单
千家信息网最后更新 2025年01月16日怎么用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安全错误
数据库的锁怎样保障安全
数据库安全漏洞工具
韩国服务器因维护处于脱机
wifi网络安全密钥忘了
网络技术实训学什么
网络安全模块龙头股
上位机软件开发要写PLC吗
网络安全维护面试不会怎么办
中国朗雅互联网科技有限公司
新乡市众诺网络技术有限公司
在数据库中插入一列
婺城区sap产品和服务器
服务器地址设置不支持
服务器的除尘方式
数据库文件选项卡中添加数据文件
智能软件开发咨询报价
登录数据库的完整语句的含义是
青少年网络安全大使
襄阳中嘉网络技术有限公司
c 数据库连接账号密码
全国数据库系统工程师
软件开发换公司吗
直播聊天室软件开发
如何查看连接到云服务器的ip
群组数据库设计
西安正信互联网科技
新余主机服务器大概费用
数据库可以只设置查询权限吗
萨格拉斯服务器公会
互联网科技发达了
c 数据库连接打开