


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):
- 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.
- 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!

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.

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

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.

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

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.

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 "

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.

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.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

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

Heißer Artikel

Heiße Werkzeuge

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

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
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

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
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.
