(原) 剑指offer--之数值的整数次方
题目描述
- #include <iostream>
- using namespace std;
- class Solution {
- public:
- double Power(double base, int exponent) {
- double result = 1.0;
- if (base == ) return 0.0;
- else if (base != && exponent == ){
- return 1.0;
- }
- else if (exponent < ){
- exponent = -exponent;
- for (int i = ; i < exponent; ++i)
- result *= base;
- return 1.0 / result; }
- else{
- for (int i = ; i < exponent; ++i)
- result *= base;
- return (double)result;
- }
- }
- };
- int main(){
- Solution su;
- double base;
- int exponent;
- while (true){
- scanf("%lf%d", &base, &exponent);
- printf ("%lf",su.Power(base, exponent));
- }
- }
找来原书看了之后,好吧我承认我智商太低。
关于代码的完整性:
1:满足基本需求。
2:对一些极端值要考虑到,比如一些边界值。
3:对一些错误输入,有相应的处理方法。
4:最好考虑到算法的效率。
下面是按着原书方法又实现了一次
全面低效的方法:
- #include <iostream>
- using namespace std;
- bool InvalidInput = false;
- bool equal(double val1, double val2)
- {
- if((val1 - val2 < 0.0000001) && (val1 - val2 > -0.0000001))
- return true;
- else
- return false;
- }
- double Power(double val, int exponent)
- {
- InvalidInput = false;
- if(equal(val, 0.0) && exponent < )
- {
- InvalidInput = true;
- return 0.0;
- }
- int absExponent = (unsigned int)(exponent);
- double rev = 1.0;
- if(exponent < )
- absExponent = (unsigned int)(-exponent);
- for(int i = ; i < absExponent; ++i)
- rev *= val;
- if(exponent < )
- return 1.0 / rev;
- else
- return rev;
- }
高效的方法:原书是这样描述的:
如果exponent = 32,按照上述方法我们要循环31次乘法,
而如果我们知道了base 的16次方可以直接平方就得到了base的32次方
同理在8次方的基础上求16次方很容易用递归实现。
- double powerwithunsign(double base, int exponent){
- if (exponent == ) return ;
- if (exponent == ) return base;
- double result = powerwithunsign(base, exponent>>);
- result *= result;
- if ((exponent & 0x1) == )
- result *= base;
- return result;
- }
(原) 剑指offer--之数值的整数次方的更多相关文章
- 《剑指offer》 数值的整数次方
本题来自<剑指offer> 数值的整数次方 题目: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 思路: 代码从三个方面处 ...
- 【剑指Offer】数值的整数次方 解题报告(Python)
[剑指Offer]数值的整数次方 解题报告(Python) 标签(空格分隔): LeetCode 题目地址:https://www.nowcoder.com/ta/coding-interviews ...
- (3)剑指Offer之数值的整数次方和调整数组元素顺序
一 数值的整数次方 题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 问题解析: 这道题算是比较麻烦和难一点的一个了.我这里采 ...
- 【Java】 剑指offer(15) 数值的整数次方
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 实现函数double Power(double base, int ...
- 【剑指offer】数值的整数次方
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/mmc_maodun/article/details/25506085 转载请注明出处:http:// ...
- Go语言实现:【剑指offer】数值的整数次方
该题目来源于牛客网<剑指offer>专题. 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 保证base和exponent不 ...
- 剑指 Offer 16. 数值的整数次方
实现函数double Power(double base, int exponent),求base的exponent次方.不得使用库函数,同时不需要考虑大数问题. 来源:力扣(LeetCode) 链接 ...
- 剑指OFFER之数值的整数次方(九度OJ1514)
题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 输入: 输入可能包含多个测试样例.对于每个输入文件,第一行输入一个整数T,表 ...
- 剑指Offer 12. 数值的整数次方 (其他)
题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 题目地址 https://www.nowcoder.com/practice/ ...
- 剑指offer:数值的整数次方
题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 解题思路: 一开始直接用一个for循环做连乘,测了一下,发现这个指数可能是负 ...
随机推荐
- Zynq7000开发系列-6(QT开发环境搭建:Ubuntu、Zynq)
操作系统:Ubuntu14.04.5 LTS 64bit Qt:Qt 5.4.2 (qt-opensource-linux-x64-5.4.2.run.qt-everywhere-opensource ...
- python 基础(六) 推导式
列表推导式 概念:提供了一种创建列表的简单快速的途径 (1) 一般形式 myList = [x for x in range(10)] #分解后 myList = [] for x in rang ...
- JavaScript引擎基本原理:Shapes和Inline Caches
原文链接: JavaScript engine fundamentals:Shapes and line Cahes 这篇文章描述了一些在js引擎中通用的关键点, 并不只是V8, 这个引擎的作者(Be ...
- Hive_Hive体系结构
元数据: HQL的执行过程 ORACEL 执行计划,Hive 类似. 无索引时,生成全表扫描执行计划,执行全表扫描. 创建索引后,重新生成SQL语句执行计划,基于索引扫描,提高查询效率.
- 用javascript编写一个简单的随机验证码程序
简单模拟网页的随机数字验证码,效果图如下: html代码: <div id="content"> <div class="left"> ...
- shell脚本由基础变量及特殊变量($@、$*、$#等)到实战。
一.shell脚本建立: shell脚本通常是在编辑器(如vi/vim)中编写,也可以在命令行中直接执行: 1.脚本开头: 规范的脚本第一行需要指出有哪个程序(解释器)来执行脚本中的内容,在L ...
- C# readonly和const的区别
什么是静态常量(Const)和动态常量(Readonly) 先解释下什么是静态常量(Const)以及什么是动态常量(Readonly). 静态常量(Const)是指编译器在编译时候会对常量进行解析,并 ...
- AJPFX分享java排序之希尔排序
(1)基本思想:算法先将要排序的一组数按某个增量d(n/2,n为要排序数的个数)分成若干组,每组中记录的下标相差d.对每组中全部元素进行直接插入排序,然后再用一个较小的增量(d/2)对它进行分组,在每 ...
- freebsd安装snmp
pkg_add http://ip地址/pub/FreeBSD/ports/packages/Latest/net-snmp.tbzFetching http://ip地址/pub/FreeBSD/p ...
- bat 批处理测试局域网速度 两端电脑
C:\Users\Administrator>iperf3 iperf3: parameter error - must either be a client (-c) or server (- ...