Java中如何編寫一個數(shù)的n次方(冪運(yùn)算)?
本文介紹了使用pow函數(shù)和自定義for循環(huán)計算冪的O(n)時間復(fù)雜度方法,然后重點講解了快速冪算法的分治思想,以及從二進(jìn)制角度的解釋,包括如何通過位運(yùn)算和循環(huán)迭代實現(xiàn)高效計算,給出了Java代碼實現(xiàn),
一、算法簡介
1.使用pow函數(shù)和自定義的for循環(huán)的時間復(fù)雜度為O(n)
/**計算x的y次方**/
//1.使用Pow函數(shù)
double res = Math.pow(x,y);
//2.自定義for循環(huán)
double res=x;
for(int i=1;i<y;i++){
res=res*x;
}2.快速冪的時間復(fù)雜度為O(log n)
二、快速冪的思想
(1)從分冶的角度出發(fā),計算 
①假設(shè)y為偶數(shù),即計算
=
我們將指數(shù) y,每次劃分為 ,上述式子不需要進(jìn)行8次循環(huán),而只需要三步即可完 成,注
和
是為了讓讀者好理解,而重復(fù)寫的。
②假設(shè)y為奇數(shù),即計算
=
指數(shù)部分為奇數(shù)是可以化解成(1+偶數(shù))的形式的,這樣我們可以把指數(shù)為1的底 拿出來當(dāng)答案來乘,偶數(shù)部分同①繼續(xù)化解即可
偽代碼
x=3,y=10,res=1
while(指數(shù)y不等于0){
if(指數(shù)y為奇數(shù)){
res = res * x //提取底數(shù)出來,作為乘積
}
y=y/2 //指數(shù)二分
x=x*x //底數(shù)平方
}(2) 從二進(jìn)制的角度出發(fā)
如8的二進(jìn)制位:8=;
二進(jìn)制轉(zhuǎn)十進(jìn)制:=
=8
那么=
=
(倒序?qū)?
觀察發(fā)現(xiàn):指數(shù)部分是由兩部分組成,第一部分是0001,第二部分是 ,發(fā)現(xiàn)2是循環(huán)增大的(用代碼x=x*x,循環(huán)迭代出來,但是否使用則看二進(jìn)制位是否為‘1’),由于二進(jìn)制要么為0要么為1(用代碼 y&1==1,來判斷)
再舉個詳細(xì)的例子(計算):
11=1011
=
偽代碼:
x=3,y=11,res=1
while( (1011)y從尾往頭讀取){
if( (y&1)==1){
res=res*x; //二進(jìn)制位不為0,則相乘
//如第一個1:res=1*3,
//第二個1:res=res*3^2
//第三個數(shù)為0:不相乘,但x是不斷平方的,此時是x^4
//第四個數(shù)為1:res=res*3^8 ,注意哦,平方是在if后面
}
二進(jìn)制右移一位
x=x*x; //依次迭代3^0,3^1,3^2,3^4,3^8................
}三、代碼實現(xiàn)
public static double FastPow(int x,int y){
double res= 1;
while (y!=0){
if(y%2 == 1){ //指數(shù)為奇數(shù),也可以利用位運(yùn)算:(y&1)==1 (與操作): 判斷 n 二進(jìn)制最右一位是否為 1
res *= x;
}
y=y/2; //指數(shù)循環(huán)二分,y>>=1 (移位操作): n 右移一位(可理解為刪除最后一位,即除以2)。
x=x*x; //底數(shù)平分
}
return res;
}
到此這篇關(guān)于Java中如何編寫一個數(shù)的n次方(冪運(yùn)算)?的文章就介紹到這了,更多相關(guān)Java中的冪運(yùn)算(冪函數(shù))內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
mybatis連接數(shù)據(jù)庫實現(xiàn)雙表查詢
本文主要介紹了mybatis連接數(shù)據(jù)庫實現(xiàn)雙表查詢,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-09-09
解決執(zhí)行maven命令時提示Process terminated的問題
這篇文章主要介紹了解決執(zhí)行maven命令時提示Process terminated的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09

