跳至內容

偽多項式時間

維基百科,自由的百科全書

這是本頁的一個歷史版本,由Zjuzhanxf對話 | 貢獻2015年5月17日 (日) 18:50編輯。這可能和目前版本存在着巨大的差異。

計算理論領域中,若一個數值算法時間複雜度可以表示為輸入數值規模N的多項式,但其運行時間與輸入數值規模N的二進制位數呈指數增長關係,則稱其時間複雜度為偽多項式時間。這是由於,N的值是N的位數的冪,故該算法的時間複雜度實際上應視為輸入數值N的位數的

一個具有偽多項式時間複雜度的NP完全問題稱之為弱NP完全問題,而在P!=NP的情況下,若一個NP完全問題被證明沒有偽多項式時間複雜度的解,則稱之為強NP完全問題

例子

素性測試中,使用較小的整數逐個對被測試數進行試除的算法被認為是一個偽多項式時間算法。對於給定的整數N,使用從最小的素數2開始,到為止的整數依次對N進行試除,如果均無法整除N,則N是素數,這個過程需要進行至多約次整數除法,即其時間複雜度為,為N的多項式。令D為N的二進制表示的位數,那麼N可以表示為以2為底D的,因此素性測試問題的時間複雜度用D表示應為。因此,上述算法是一個偽多項式時間算法。

其它被證明只具有偽多項式時間算法解的問題有背包問題子集合加總問題