剑指offer第二版-16数值的整数次方

2024-04-25 13:48

本文主要是介绍剑指offer第二版-16数值的整数次方,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/*** 数值的整数次方* <p>* 实现函数double power(double base,int exponent),求base的exponent次方。不能使用库函数,不需要考虑大数问题。* 可能我们的第一想法永远是利用循环进行求值,如果要考虑到0和整数,可以将指数先求绝对值,然后算出结果后取倒数。* 既然要求倒数,我们很自然的想到,有没有可能对0取倒数* 同时需要说明,0的零次方是没有意义的,返回0或者1都可以* 这样的话 我们可能需要循环指数-1次* <p>* 如果输入的指数是32.那么需要循环31次,我们换一种思路:* 我们的目标是求一个数字的32次方,如果我们知道它的16次方,那么只要在16次方的基础上在平方就可以了* 而16是8次方的平方,以此类推,求32次方只需要做5次乘法* 如果是奇数,则再多求一次乘法** @author VicterTian* @version V1.0* @Date 2019/2/9*/
public class P110_PowerNumber {private static boolean invalidInput = false;private static double power(double base, int exponent) {if (exponent == 0) {return 1;}if (exponent == 1) {return base;}if (exponent < 0) {if (equal(base, 0)) {invalidInput = true;return -1;} else {return 1.0 / powerWithPositiveExponent(base, -1 * exponent);}} else {return powerWithPositiveExponent(base, exponent);}}private static double powerWithPositiveExponent(double base, int exponent) {if (exponent == 0) {return 1;}if (exponent == 1) {return base;}double result = powerWithPositiveExponent(base, exponent >> 1);result = result * result;// 用位于运算代替取余符号判断一个数是偶数还是奇数if ((exponent & 0x1) == 1) {result = base * result;}return result;}private static boolean equal(double base, int i) {return -0.00001 < base - i && base - i < 0.00001;}public static void main(String[] args) {System.out.println("2^3=" + power(2, 3) + "\t是否报错:" + invalidInput);System.out.println("2^-3=" + power(2, -3) + "\t是否报错:" + invalidInput);System.out.println("0^3=" + power(0, 3) + "\t是否报错:" + invalidInput);System.out.println("0^-3=" + power(0, -3) + "\t是否报错:" + invalidInput);}
}

这篇关于剑指offer第二版-16数值的整数次方的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/934855

相关文章

闲置电脑也能活出第二春?鲁大师AiNAS让你动动手指就能轻松部署

对于大多数人而言,在这个“数据爆炸”的时代或多或少都遇到过存储告急的情况,这使得“存储焦虑”不再是个别现象,而将会是随着软件的不断臃肿而越来越普遍的情况。从不少手机厂商都开始将存储上限提升至1TB可以见得,我们似乎正处在互联网信息飞速增长的阶段,对于存储的需求也将会不断扩大。对于苹果用户而言,这一问题愈发严峻,毕竟512GB和1TB版本的iPhone可不是人人都消费得起的,因此成熟的外置存储方案开

PTA求一批整数中出现最多的个位数字

作者 徐镜春 单位 浙江大学 给定一批整数,分析每个整数的每一位数字,求出现次数最多的个位数字。例如给定3个整数1234、2345、3456,其中出现最多次数的数字是3和4,均出现了3次。 输入格式: 输入在第1行中给出正整数N(≤1000),在第二行中给出N个不超过整型范围的非负整数,数字间以空格分隔。 输出格式: 在一行中按格式“M: n1 n2 ...”输出,其中M是最大次数,n

整数Hash散列总结

方法:    step1  :线性探测  step2 散列   当 h(k)位置已经存储有元素的时候,依次探查(h(k)+i) mod S, i=1,2,3…,直到找到空的存储单元为止。其中,S为 数组长度。 HDU 1496   a*x1^2+b*x2^2+c*x3^2+d*x4^2=0 。 x在 [-100,100] 解的个数  const int MaxN = 3000

《数据结构(C语言版)第二版》第八章-排序(8.3-交换排序、8.4-选择排序)

8.3 交换排序 8.3.1 冒泡排序 【算法特点】 (1) 稳定排序。 (2) 可用于链式存储结构。 (3) 移动记录次数较多,算法平均时间性能比直接插入排序差。当初始记录无序,n较大时, 此算法不宜采用。 #include <stdio.h>#include <stdlib.h>#define MAXSIZE 26typedef int KeyType;typedef char In

CSP 2023 提高级第一轮 CSP-S 2023初试题 完善程序第二题解析 未完

一、题目阅读 (最大值之和)给定整数序列 a0,⋯,an−1,求该序列所有非空连续子序列的最大值之和。上述参数满足 1≤n≤105 和 1≤ai≤108。 一个序列的非空连续子序列可以用两个下标 ll 和 rr(其中0≤l≤r<n0≤l≤r<n)表示,对应的序列为 al,al+1,⋯,ar​。两个非空连续子序列不同,当且仅当下标不同。 例如,当原序列为 [1,2,1,2] 时,要计算子序列 [

【JavaScript】LeetCode:16-20

文章目录 16 无重复字符的最长字串17 找到字符串中所有字母异位词18 和为K的子数组19 滑动窗口最大值20 最小覆盖字串 16 无重复字符的最长字串 滑动窗口 + 哈希表这里用哈希集合Set()实现。左指针i,右指针j,从头遍历数组,若j指针指向的元素不在set中,则加入该元素,否则更新结果res,删除集合中i指针指向的元素,进入下一轮循环。 /*** @param

16 子组件和父组件之间传值

划重点 子组件 / 父组件 定义组件中:props 的使用组件中:data 的使用(有 return 返回值) ; 区别:Vue中的data (没有返回值);组件方法中 emit 的使用:emit:英文原意是:触发、发射 的意思components :直接在Vue的方法中声明和绑定要使用的组件 小炒肉:温馨可口 <!DOCTYPE html><html lang="en"><head><

react笔记 8-16 JSX语法 定义数据 数据绑定

1、jsx语法 和vue一样  只能有一个根标签 一行代码写法 return <div>hello world</div> 多行代码返回必须加括号 return (<div><div>hello world</div><div>aaaaaaa</div></div>) 2、定义数据 数据绑定 constructor(){super()this.state={na

单精度浮点数按存储格式转为整数的程序

///#include<cstdio>//-----------------union int_char{unsigned char ch[4];float i;};void out_put(union int_char x)//x86是小端对其模式,即最数据的最低位存储在地址的最低位上。{printf("单精度浮点数值为:%f\n",x.i,x.i);printf("存储位置从左到右

20190315 把整理和培养自己当作一生的事业,而不是局限在找工作拿offer。

把整理和培养自己当作一生的事业,而不是局限在找工作拿offer,做有本事的人。 来东南读研半年了,明显感觉自己掌握的不过是书本知识级别的中上水平,垃圾收集器这些的只知道背面经,靠脑子硬记,缺乏整理和系统,一头浆糊。 现在一边做实训这个烂项目,一边刷面经,一边刷剑指offer,想投些大公司的实习,又觉得还没准备好,看着各 种面经,都能说个大概,但明显感觉到自己知识的不体系和不深入,**做的项目