一種最快地確定一個整數的平方根是否為整數的方法
問題說明
我正在尋找最快的方法來確定一個長整數是否為一個完全平方(即它的平方根是另一個整數):
- 我使用內建的Math.sqrt() 函數完成了它,但我很好奇是否有一種方法可以使用整數域來完成,從而提高速度。
- 維護一個查找表是不切實際的(因為有大約 231.5 個整數的平方小於 263)。
以下是我現在完成它的非常簡單直接的方法:
public final static boolean isPerfectSquare(long n)<br>{<br> if (n <pre class="brush:php;toolbar:false">return false;
long tst = (long)(Math.sqrt(n) 0.5);
return tst*tst == n;
}
注意:我在許多Project Euler 問題中使用了這個函數。因此,以後將不會對這一段程式碼進行任何維護。而這種微型最佳化實際上可以帶來差異,因為挑戰的一部分是用不到一分鐘的時間完成每個演算法,而此函數需要在某些問題中被呼叫數百萬次。
我已經嘗試了解決這個問題的不同方案:
- 經過詳盡的測試,我發現向 Math.sqrt() 的結果添加 0.5 is 不必要的,至少在我的機器上是這樣。
- 快速反平方根比 Math.sqrt() 快,但對於 n >= 410881 給出了不正確的結果。然而,正如 BobbyShaftoe 所建議的,我們可以為 n
- Newton's 方法比 Math.sqrt() 慢很多。這可能是因為 Math.sqrt() 使用類似於 Newton 方法的東西,但是在硬體中實現,因此比 Java 中的速度快得多。此外,Newton 方法仍需要使用雙精確度浮點數。
- 一種經過改進的Newton 方法,它利用了一些技巧,使其只需要進行整數運算,在避免溢出時也需要一些技巧(我希望該函數可以處理所有正的64 位元有符號整數),而且它比Math.sqrt() 慢。
- 二分查找甚至更慢。這是有道理的,因為二分查找平均需要進行 16 次傳遞才能找到 64 位數字的平方根。
- 根據 John 的測試,在 C 中使用或語句比使用開關速度更快,但在 Java 和 C# 中,或和開關之間似乎沒有區別。
- 我還嘗試製作一個查找表(作為 64 個布林值的私人靜態數組)。然後,不是使用 switch 或 or 語句,我會直接說 if(lookup[(int)(n&0x3F)]) { test } else return false;. 令我驚訝的是,這(略微)慢了一些。這是因為數組邊界在 Java 中是受檢的。
以上是確定整數的平方根是否為整數的最快方法是什麼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Java如何緩解平台特定的問題? Java通過JVM和標準庫來實現平台無關性。 1)使用字節碼和JVM抽像操作系統差異;2)標準庫提供跨平台API,如Paths類處理文件路徑,Charset類處理字符編碼;3)實際項目中使用配置文件和多平台測試來優化和調試。

java'splatformentenceenhancesenhancesmicroservicesharchitecture byferingDeploymentFlexible,一致性,可伸縮性和便攜性。 1)DeploymentFlexibilityAllowsibilityAllowsOllowsOllowSorlowsOllowsOllowsOllowSeStorunonAnyPlatformwithajvM.2)penterencyCrossServAccAcrossServAcrossServiCessImplifififiesDeevelopmentandeDe

GraalVM通過三種方式增強了Java的平台獨立性:1.跨語言互操作,允許Java與其他語言無縫互操作;2.獨立的運行時環境,通過GraalVMNativeImage將Java程序編譯成本地可執行文件;3.性能優化,Graal編譯器生成高效的機器碼,提升Java程序的性能和一致性。

效率testjavaapplicationsforplatformcompatibility oftheSesteps:1)setUpautomatedTestingTestingActingAcrossMultPlatFormSusingCitoolSlikeSlikeJenkinSorgithUbactions.2)contuctualtemualtemalualTesteTESTENRETESTINGINREALHARTWARETOLEALHARDOELHARDOLEATOCATCHISSUSESUSEUSENINCIENVIRENTMENTS.3)schictcross.3)schoscross.3)

Java編譯器通過將源代碼轉換為平台無關的字節碼,實現了Java的平台獨立性,使得Java程序可以在任何安裝了JVM的操作系統上運行。

ByteCodeachievesPlatFormIndenceByByByByByByExecutedBoviratualMachine(VM),允許CodetorunonanyplatformwithTheApprepreprepvm.Forexample,Javabytecodecodecodecodecanrunonanydevicewithajvm

Java不能做到100%的平台獨立性,但其平台獨立性通過JVM和字節碼實現,確保代碼在不同平台上運行。具體實現包括:1.編譯成字節碼;2.JVM的解釋執行;3.標準庫的一致性。然而,JVM實現差異、操作系統和硬件差異以及第三方庫的兼容性可能影響其平台獨立性。

Java通過“一次編寫,到處運行”實現平台獨立性,提升代碼可維護性:1.代碼重用性高,減少重複開發;2.維護成本低,只需一處修改;3.團隊協作效率高,方便知識共享。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

禪工作室 13.0.1
強大的PHP整合開發環境

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

ZendStudio 13.5.1 Mac
強大的PHP整合開發環境