java中幂指数值的运算代码解析
程序员文章站
2023-12-04 11:29:04
说到幂指数的运算我们就会用到math.pow(doublea,doubleb),返回的结果是a的b次方。
在java中,当我们计算2的n次方时,可以直接用math.pow...
说到幂指数的运算我们就会用到math.pow(doublea,doubleb),返回的结果是a的b次方。
在java中,当我们计算2的n次方时,可以直接用math.pow来计算。非常方便。
但是,已知一个幂的结果为m和幂的底数a,现在要求幂的指数n。math中提供的有log(double)方法,但是只能传入一个参数,即m。那么问题来了,如何简单、方便、快捷的达到我们的要求呢?答案如下:
n=math.log(m)/math.log(a);
这个方法可以满足我们大多数幂指数的计算,但是每次访问的值和传入的值都是double,自己不想去转的话怎么办,我们有一种新的方案。
方案前提:幂指数的底数是2的倍数。
这里我们就用到了移位运算(移位运算是基于二进制来的,所以方案前提就是这个依据),如我们求2的3次方,我们可以用2<<(3-1)来计算出结果。
4的2次方,我们先要把4转化为2的2次方,再来2<<(4-1)来计算出结果。
下面这个方法实现的效果是我们传入一个2的倍数相加的两个数,比如12(是4+8),我们把它自动计算出[4,8]
再比如18,我们把它计算出[2,16]
再比如22,我们把它计算出[2,4,16]
/** * 以2的次方开始的转换成整型数组,字符串数组 * @param sum 传入派系的值,可以是一个派系的值,也可以是多个派系相加的值 * 2^1 + 2^2 这种 * 突然忘记移位操作也是一种指数幂的运算 * @return */ private static int[] tougrouparray(int sum){ if(sum < 0){ system.out.println("you have an eroor code"); } else if(sum == 0) { system.out.println("you have no choise code"); } else{ string binarycode = integer.tobinarystring(sum); system.out.println("binary code:"+binarycode); int index = binarycode.length() -1; string str = ""; for (int i=0;i<binarycode.length();i++){ if(binarycode.charat(i) == '1'){ str = str + index +","; } index --; } str = str.substring(0, str.length()-1); system.out.println(str); string[] strarray = str.split(","); int[] result = new int[strarray.length]; //也可以返回一个字符数组 //string[] result2 = new string[strarray.length]; for (int i=0;i<strarray.length;i++){ //result[i] = (int)math.pow(2, double.parsedouble(strarray[i])); result[i] = 2 << (integer.parseint(strarray[i])-1); } return result; } return null; }
总结
以上就是本文关于java中幂指数值的运算代码解析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
推荐阅读
-
java中幂指数值的运算代码解析
-
荐 Java中多线程的使用(超级超级详细)线程安全+线程锁原理解析+保证线程安全的三种方式 (同步代码块+同步方法+lock锁) 5
-
Java中工厂模式的图文代码解析
-
Java中工厂模式的图文代码解析
-
Java中transient关键字的用法解析(代码)
-
java中多态的深入解析(代码示例)
-
解析java中的char占几个字节实例代码
-
关于Java中Socket设置连接超时的代码案例解析
-
荐 Java中多线程的使用(超级超级详细)线程安全+线程锁原理解析+保证线程安全的三种方式 (同步代码块+同步方法+lock锁) 5
-
Java中String字符串运算的介绍(代码示例)