suchen
HeimJavajavaLernprogrammWie kann man am schnellsten feststellen, ob die Quadratwurzel einer ganzen Zahl eine ganze Zahl ist?

What's the Fastest Way to Determine if the Square Root of an Integer is an Integer?

Der schnellste Weg, um festzustellen, ob die Quadratwurzel einer ganzen Zahl eine ganze Zahl ist

Problembeschreibung

Ich suche das schnellster Weg Methode zur Bestimmung, ob eine lange ganze Zahl ein perfektes Quadrat ist (d. h. ihre Quadratwurzel ist eine andere ganze Zahl):


  1. Ich habe es mit der integrierten Funktion Math.sqrt() gemacht, bin aber gespannt, ob es eine Möglichkeit gibt, das zu machen Verwendung von Ganzzahlfeldern, wodurch die Geschwindigkeit erhöht wird.

  2. Es ist unpraktisch, eine Nachschlagetabelle zu verwalten (da es ungefähr 231,5 ganze Zahlen gibt, deren Quadrate kleiner als 263 sind).

Hier ist die ganz einfache und unkomplizierte Art, wie ich es jetzt mache:

{<br> if (n <pre class="brush:php;toolbar:false">return false;

long tst = (long)(Math.sqrt(n) 0.5);
return tst*tst == n;
}

Hinweis: Ich verwende diese Funktion in vielen Project Euler-Problemen. Daher wird dieser Code in Zukunft nicht mehr gewartet. Und diese Mikrooptimierung kann tatsächlich einen Unterschied machen, denn ein Teil der Herausforderung besteht darin, dass die Fertigstellung jedes Algorithmus weniger als eine Minute dauert, während diese Funktion bei manchen Problemen millionenfach aufgerufen werden muss.


Ich habe verschiedene Lösungen für dieses Problem ausprobiert:


  • Nach ausführlichen Tests habe ich festgestellt, dass das Hinzufügen von 0,5 zum Ergebnis von Math.sqrt() zumindest auf meinem Computer unnötig ist.

  • Schnelle inverse Quadratwurzel ist schneller als Math.sqrt(), liefert aber falsche Ergebnisse für n >= 410881. Allerdings können wir, wie BobbyShaftoe vorgeschlagen hat, den FISR-Hack für n
  • Newtons Methode ist viel langsamer als Math.sqrt(). Dies liegt wahrscheinlich daran, dass Math.sqrt() etwas Ähnliches wie Newtons Methode verwendet, jedoch in Hardware implementiert und daher viel schneller als in Java ist. Darüber hinaus erfordert die Newton-Methode immer noch die Verwendung von Gleitkommazahlen mit doppelter Genauigkeit.
  • positive 64-Bit-Ganzzahl mit Vorzeichen) und ist langsamer als Math.sqrt().
  • Die binäre Suche ist noch langsamer. Dies ist sinnvoll, da eine binäre Suche durchschnittlich 16 Durchgänge erfordert, um die Quadratwurzel einer 64-Bit-Zahl zu finden.

  • Laut Johns Tests ist die Verwendung einer or-Anweisung schneller als die Verwendung eines Schalters in C, aber in Java und C# scheint es keinen Unterschied zwischen einem or und einem Schalter zu geben.

  • Ich habe auch versucht, eine Nachschlagetabelle zu erstellen (als privates statisches Array mit 64 booleschen Werten). Anstatt eine switch- oder or-Anweisung zu verwenden, würde ich dann einfach if(lookup[(int)(n&0x3F)]) { test } else return false; sagen. Zu meiner Überraschung ist dies (etwas) langsamer. Dies liegt daran, dass Array-Grenzen in Java überprüft werden.


Das obige ist der detaillierte Inhalt vonWie kann man am schnellsten feststellen, ob die Quadratwurzel einer ganzen Zahl eine ganze Zahl ist?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Was sind einige Strategien, um plattformspezifische Probleme in Java-Anwendungen zu mildern?Was sind einige Strategien, um plattformspezifische Probleme in Java-Anwendungen zu mildern?May 01, 2025 am 12:20 AM

Wie lindert Java plattformspezifische Probleme? Java implementiert plattformunabhängig über JVM- und Standardbibliotheken. 1) Bytecode und JVM verwenden, um die Unterschiede für das Betriebssystem abstrahieren; 2) Die Standardbibliothek bietet plattformübergreifende APIs wie Pfade der Klassenverarbeitungsdateien und die Codierung von Charset Class Processing. 3) Verwenden Sie Konfigurationsdateien und Multi-Plattform-Tests in tatsächlichen Projekten zur Optimierung und Debuggierung.

Wie ist die Beziehung zwischen der Unabhängigkeit der Java -Plattform und der Microservices -Architektur?Wie ist die Beziehung zwischen der Unabhängigkeit der Java -Plattform und der Microservices -Architektur?May 01, 2025 am 12:16 AM

Java'SplatformIndependenceEnhancesMicroservicesArchitecture byFeringDeploymentFlexibilität, Konsistenz, Skalierbarkeit und Portabilität.1) EinsatzFlexibilitätsmarkroservicestorunonanyplatformwithajvm.2) konsistenzacrossservicessimplimplimplifiesDevention und

Wie bezieht sich Graalvm auf die Unabhängigkeitsziele der Plattform von Java?Wie bezieht sich Graalvm auf die Unabhängigkeitsziele der Plattform von Java?May 01, 2025 am 12:14 AM

Graalvm verbessert die Unabhängigkeit der Java-Plattform auf drei Arten: 1. Cross-Sprach-Interoperabilität und ermöglicht es Java, nahtlos mit anderen Sprachen zusammenzuarbeiten; 2. Unabhängige Laufzeitumgebung, kompilieren Sie Java -Programme in lokale ausführbare Dateien über GraalvmnativeImage; 3. Die Leistungsoptimierung generiert Graal Compiler einen effizienten Maschinencode, um die Leistung und Konsistenz von Java -Programmen zu verbessern.

Wie testen Sie Java -Anwendungen auf Plattformkompatibilität?Wie testen Sie Java -Anwendungen auf Plattformkompatibilität?May 01, 2025 am 12:09 AM

ToeffectiveTeTestJavaApplicationsforplatformCompatibilität, folgt der THESESTEPS: 1) SetupautomatedTestingAcrossMultiPlatformseususecitools-ähnlichemkinsorgithubactions.2) DirimesManualTestingonRealhardwaretocatchissusisNotFoundincincien-Birgen.3) checkcross-pla

Welche Rolle spielt der Java -Compiler (Javac) bei der Erreichung der Unabhängigkeit der Plattform?Welche Rolle spielt der Java -Compiler (Javac) bei der Erreichung der Unabhängigkeit der Plattform?May 01, 2025 am 12:06 AM

Der Java-Compiler erkennt die Unabhängigkeit der Java-Plattform, indem es den Quellcode in plattformunabhängige Bytecode konvertiert und Java-Programmen mit installiertem Betriebssystem mit JVM ausgeführt wird.

Was sind die Vorteile der Verwendung von Bytecode gegenüber dem nativen Code für die Unabhängigkeit von Plattform?Was sind die Vorteile der Verwendung von Bytecode gegenüber dem nativen Code für die Unabhängigkeit von Plattform?Apr 30, 2025 am 12:24 AM

BytecodeachieVesplattformindependencyBeineingexecutedByavirtualMachine (VM), ZulassencodetorunonanyPlatformWiththeApprotecuse -Forexample, JavabytecodecanrunonanyDeviceWithajvm, Enabling "Writeonce, Runanywhere," Funktionalität "Funktionalität" Funktionalität "Funktionalität" Funktionalität "Funktionalität" Funktionalität "Funktionalität" Funktionalität "Funktionalität" functionaly.- "Funktionalität" Funktionalität "

Ist Java wirklich 100% plattformunabhängig? Warum oder warum nicht?Ist Java wirklich 100% plattformunabhängig? Warum oder warum nicht?Apr 30, 2025 am 12:18 AM

Java kann keine 100% ige Plattformunabhängigkeit erreichen, aber die Unabhängigkeit der Plattform wird über JVM und Bytecode implementiert, um sicherzustellen, dass der Code auf verschiedenen Plattformen ausgeführt wird. Spezifische Implementierungen umfassen: 1. Zusammenstellung in Bytecode; 2. Interpretation und Ausführung von JVM; 3. Konsistenz der Standardbibliothek. JVM-Implementierungsunterschiede, Betriebssystem- und Hardwareunterschiede sowie die Kompatibilität von Bibliotheken von Drittanbietern können sich jedoch auf die Unabhängigkeit der Plattform auswirken.

Wie unterstützt Javas Plattform -Unabhängigkeits -Code -Wartbarkeit?Wie unterstützt Javas Plattform -Unabhängigkeits -Code -Wartbarkeit?Apr 30, 2025 am 12:15 AM

Java realisiert die Unabhängigkeit der Plattform durch "einmal schreiben, überall rennen" und verbessert die Code -Wartbarkeit: 1. REUSE der Code und reduziert die doppelte Entwicklung; 2. Niedrige Wartungskosten, es ist nur eine Änderung erforderlich; 3. Die Effizienz der High -Team -Kollaboration ist hoch und bequem für den Wissensaustausch.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.

SAP NetWeaver Server-Adapter für Eclipse

SAP NetWeaver Server-Adapter für Eclipse

Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

mPDF

mPDF

mPDF ist eine PHP-Bibliothek, die PDF-Dateien aus UTF-8-codiertem HTML generieren kann. Der ursprüngliche Autor, Ian Back, hat mPDF geschrieben, um PDF-Dateien „on the fly“ von seiner Website auszugeben und verschiedene Sprachen zu verarbeiten. Es ist langsamer und erzeugt bei der Verwendung von Unicode-Schriftarten größere Dateien als Originalskripte wie HTML2FPDF, unterstützt aber CSS-Stile usw. und verfügt über viele Verbesserungen. Unterstützt fast alle Sprachen, einschließlich RTL (Arabisch und Hebräisch) und CJK (Chinesisch, Japanisch und Koreanisch). Unterstützt verschachtelte Elemente auf Blockebene (wie P, DIV),

Sicherer Prüfungsbrowser

Sicherer Prüfungsbrowser

Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.