java中冪指數(shù)值的運(yùn)算代碼解析
說到冪指數(shù)的運(yùn)算我們就會用到Math.pow(doublea,doubleb),返回的結(jié)果是a的b次方。
在Java中,當(dāng)我們計(jì)算2的n次方時,可以直接用Math.pow來計(jì)算。非常方便。
但是,已知一個冪的結(jié)果為M和冪的底數(shù)a,現(xiàn)在要求冪的指數(shù)n。Math中提供的有l(wèi)og(double)方法,但是只能傳入一個參數(shù),即M。那么問題來了,如何簡單、方便、快捷的達(dá)到我們的要求呢?答案如下:
n=Math.log(M)/Math.log(a);
這個方法可以滿足我們大多數(shù)冪指數(shù)的計(jì)算,但是每次訪問的值和傳入的值都是double,自己不想去轉(zhuǎn)的話怎么辦,我們有一種新的方案。
方案前提:冪指數(shù)的底數(shù)是2的倍數(shù)。
這里我們就用到了移位運(yùn)算(移位運(yùn)算是基于二進(jìn)制來的,所以方案前提就是這個依據(jù)),如我們求2的3次方,我們可以用2<<(3-1)來計(jì)算出結(jié)果。
4的2次方,我們先要把4轉(zhuǎn)化為2的2次方,再來2<<(4-1)來計(jì)算出結(jié)果。
下面這個方法實(shí)現(xiàn)的效果是我們傳入一個2的倍數(shù)相加的兩個數(shù),比如12(是4+8),我們把它自動計(jì)算出[4,8]
再比如18,我們把它計(jì)算出[2,16]
再比如22,我們把它計(jì)算出[2,4,16]
/**
* 以2的次方開始的轉(zhuǎn)換成整型數(shù)組,字符串?dāng)?shù)組
* @param sum 傳入派系的值,可以是一個派系的值,也可以是多個派系相加的值
* 2^1 + 2^2 這種
* 突然忘記移位操作也是一種指數(shù)冪的運(yùn)算
* @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];
//也可以返回一個字符數(shù)組
//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;
}
總結(jié)
以上就是本文關(guān)于java中冪指數(shù)值的運(yùn)算代碼解析的全部內(nèi)容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
相關(guān)文章
SSH框架網(wǎng)上商城項(xiàng)目第28戰(zhàn)之使用Ajax技術(shù)局部更新商品數(shù)量和總價
這篇文章主要為大家詳細(xì)介紹了SSH框架網(wǎng)上商城項(xiàng)目第28戰(zhàn)之使用Ajax技術(shù)局部更新商品數(shù)量和總價,感興趣的小伙伴們可以參考一下2016-06-06

