题目描述: 实现函数double Power(double base, int exponent),求base的exponent次方,不得使用库函数,同时不需要考虑大数问题 思路:本题的重点考察内容是代码的完整性,要综合考虑输入的合法性,边界值等等,同时也可以进行优化 实现一: public double Power(double base, int exponent){ double result = 1.0; for(int i = 0; i < exponent; i++){ result…
剑指Offer - 九度1514 - 数值的整数次方2013-11-30 00:49 题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 输入: 输入可能包含多个测试样例.对于每个输入文件,第一行输入一个整数T,表示测试案例的数目,接下来的T行每行输入一个浮点数base和一个整数exponent,两个数中间用一个空格隔开. 输出: 对应每个测试案例,输出一个浮点数代表答案,保留两位小数即可. 样例输入: 5 1.0 10 0…
测试通过代码: package t0825; public class Power { public static void main(String[] args){ System.out.println(Power(2.5,3)); System.out.println(Power(0.00000001,3)); System.out.println(Power(0.00000001,-3)); System.out.println(Power(2,-3)); System.out.print…
题目描述 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 题目分析 这道题用传统的方法也可以做,只不过效率太低,这里我们用到快速幂的方法.不懂可以百度搜快速幂,原理如下: 也就是说我们要算a的11次方,我们只需要算a的1次方,a的2次方,a的8次方,也就是说我们结果需要算的是这个指数对应的二进制数上有1的位, 比如1011,所以          好了,此外再说一句,对1进行按位与,可以判断二进制数最右边的位数是否为1,因此也可以判…
一.题目 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 二.思路 1.传统方法计算,时间复杂度O(n) 2.递归方式计算,时间复杂度O(logn) 当exponent为偶数时,例如求base^10,则result= base^5  *  base^5: 当exponent为奇数数时,例如求base^11,则result= base^5 *  base^5 * base: 接着采用递归的方法,计算base^5 即可. 三.代码 1.…
  题目描述:   给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方.   解题思路:   本题看似比较简单,是一个简单的指数运算,但需要完整的考虑到所有情况.首先,对于底数,如果底数为0,则0的任何次方都是0,可以直接返回0.关键在于指数,指数可能有三种情况,有可能是正数.0.负数.对于指数是0的情况,任何数的0次方为1.对于指数是负数的情况,可以将其转化为绝对值计算,求出结果之后再求倒数.   在计算n次方的时候,为了方便,我们根据…
面试题 16. 数值的整数次方 题目描述 题目:给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 解答过程 下面的讨论中 x 代表 base,n 代表 exponent. 因为 (x*x)n/2 可以通过递归求解,并且每递归一次,n 都减小一半,因此整个算法的时间复杂度为 O(logn). 代码实现 方法一 public class Solution { public double Power(double x, int n) { i…
// 面试题16:数值的整数次方 // 题目:实现函数double Power(double base, int exponent),求base的exponent // 次方.不得使用库函数,同时不需要考虑大数问题. #include <iostream> #include <cmath> bool g_InvalidInput = false; bool equal(double num1, double num2); double PowerWithUnsignedExpone…
leetcode上也见过一样的题,当时不会做 看了一下解法是纯数学解法就没看,结果剑指offer上也出现了这道题,那还是认真看下吧 对于数字abcde,如果第一位是1,比如12345,即计算f(12345). 那么首位为1对结果的增益一共是10000到12345一共2346个. 另外首位为1的数字,后四位还可能有1出现,这部分即0001到2345(对应的数字就是10001到12345),也递归解决 f(2345). 还有10000以下的数字(即4位数),这部分交给递归解决f(9999). 如果第…
面试题16:反转链表 提交网址: http://www.nowcoder.com/practice/75e878df47f24fdc9dc3e400ec6058ca?tpId=13&tqId=11168 或 https://leetcode.com/problems/reverse-linked-list/ Total Accepted: 101523  Total Submissions: 258623  Difficulty: Easy Reverse a singly linked lis…