Dieses Tutorial zeigt zwei Methoden zur Beseitigung von sogar Zahlen aus einem Java -Stapel. Stapel, die das LEFO-Prinzip (Last-In-First-Out) halten, stellen eine einzigartige Herausforderung für diese Art der Filterung dar. Die hier gezeigten Techniken sind an andere Filterszenarien anpassbar, die über die einfachen Zahlen hinausgehen.
Das Problem:
Schreiben Sie ein Java -Programm, um alle gleichmäßigen Zahlen zu entfernen.
Beispieleingänge und Ausgänge:
- Eingabe 1:
[1, 2, 3, 4, 5]
Ausgabe 1:[1, 3, 5]
- Eingabe 2:
[1, 7, 3, 11, 9]
Ausgabe 2:[1, 7, 3, 11, 9]
(keine gleichmäßigen Zahlen zu entfernen)
Lösungsansätze:
Wir werden zwei unterschiedliche Ansätze untersuchen:
-
Verwenden eines Hilfsstapels: Diese Methode verwendet einen temporären Stapel, um ungerade Zahlen zu speichern, während sie durch den Originalstapel iteriert.
-
Verwenden von Rekursion: Dieser rekursive Ansatz verarbeitet den Stapel effizient und entzieht gleichmäßige Zahlen während der rekursiven Aufrufe.
Methode 1: Hilfsstapel
Dieser Ansatz beinhaltet die folgenden Schritte:
- Erstellen Sie ein temporäres
Stack
(z. B.tempStack
). - durch den Originalstapel iterieren und jedes Element knallen.
- Wenn das Element ungerade ist (prüfen Sie mit dem Modulo -Operator
%
), drücken Sie es auftempStack
. - Sobald der Originalstapel leer ist, übertragen Sie Elemente von
tempStack
zurück zum Originalstapel.
Code -Beispiel (Hilfsstapel):
import java.util.Stack; public class RemoveEvenElements { public static void removeEven(Stack<Integer> stack) { Stack<Integer> tempStack = new Stack<>(); while (!stack.isEmpty()) { int element = stack.pop(); if (element % 2 != 0) { tempStack.push(element); } } while (!tempStack.isEmpty()) { stack.push(tempStack.pop()); } } public static void main(String[] args) { Stack<Integer> stack = new Stack<>(); stack.push(1); stack.push(2); stack.push(3); stack.push(4); stack.push(5); removeEven(stack); System.out.println(stack); // Output: [1, 3, 5] } }
Zeit- und Raumkomplexität (Hilfsstapel):
- Zeitkomplexität: o (n) - Wir iterieren zweimal durch den Stapel.
- Raumkomplexität: o (n) - Wir verwenden einen Hilfsstapel mit potenziell gleicher Größe wie der Eingangsstapel.
Methode 2: Rekursion
Diese rekursive Lösung behandelt die gleichmäßige Zahlenentfernung elegant:
- Basisfall: Wenn der Stapel leer ist, kehren Sie zurück.
- das obere Element pop.
- rufen Sie die Funktion
removeEven
rekursiv auf, um den verbleibenden Stapel zu verarbeiten. - Nach dem rekursiven Anruf prüfen Sie, ob das gepackte Element ungerade ist. Wenn ja, schieben Sie es wieder auf den Stapel.
Code -Beispiel (Rekursion):
import java.util.Stack; public class RemoveEvenElements { public static void removeEven(Stack<Integer> stack) { if (stack.isEmpty()) { return; } int element = stack.pop(); removeEven(stack); if (element % 2 != 0) { stack.push(element); } } public static void main(String[] args) { Stack<Integer> stack = new Stack<>(); stack.push(1); stack.push(2); stack.push(3); stack.push(4); stack.push(5); removeEven(stack); System.out.println(stack); // Output: [1, 3, 5] } }
Zeit- und Raumkomplexität (Rekursion):
- Zeitkomplexität: o (n) - Wir durchqueren den Stapel rekursiv.
- Raumkomplexität: o (n) - Der rekursive Anrufstapel kann im schlimmsten Fall bis zur Größe des Eingangsstapels wachsen.
Schlussfolgerung:
Beide Methoden entfernen effektiv gleiche Zahlen aus einem Stapel. Der Hilfsstapelansatz ist einfacher, während der rekursive Ansatz eine prägnantere und möglicherweise etwas effizientere Lösung bietet (abhängig von der Optimierung des JVM). Die Wahl hängt von der persönlichen Präferenz und dem Codierungsstil ab. Denken Sie daran, dass diese Techniken an Filterstapeln basierend auf verschiedenen Kriterien angepasst werden können.
Das obige ist der detaillierte Inhalt vonLöschen Sie alle sogar Elemente aus einem Stapel in Java. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

JVM arbeitet mit dem Konvertieren von Java -Code in Maschinencode und Verwaltung von Ressourcen. 1) Ladeklasse: Laden Sie die .class -Datei in den Speicher. 2) Laufzeitdatenbereich: Speicherbereich verwalten. 3) Ausführungs Engine: Ausführungsbytecode interpretieren oder kompilieren. 4) Lokale Methodenschnittstelle: Interagieren Sie mit dem Betriebssystem über JNI.

Mit JVM kann Java auf Plattformen rennen. 1) JVM lädt, validiert und führt Bytecode aus. 2) Die Arbeit von JVM umfasst Klassenbelastung, Bytecode -Überprüfung, Interpretationsausführung und Speicherverwaltung. 3) JVM unterstützt erweiterte Funktionen wie dynamisches Klassenbelastung und Reflexion.

Java -Anwendungen können in verschiedenen Betriebssystemen in den folgenden Schritten ausgeführt werden: 1) Verwenden Sie die Datei- oder Pfadeklasse, um Dateipfade zu verarbeiten; 2) Umgebungsvariablen durch system.getenv () einstellen und erhalten; 3) Verwenden Sie Maven oder Gradle, um Abhängigkeiten zu verwalten und zu testen. Die plattformübergreifenden Funktionen von Java beruhen auf der Abstraktionsschicht der JVM, erfordern jedoch eine manuelle Handhabung bestimmter Betriebssystem-spezifischer Funktionen.

Java benötigt eine spezifische Konfiguration und das Tuning auf verschiedenen Plattformen. 1) Passen Sie die JVM -Parameter an, z. B. -xms und -xmx, um die Haufengröße festzulegen. 2) Wählen Sie die entsprechende Strategie für die Müllsammlung, wie z. B. ParallelgC oder G1GC. 3) Konfigurieren Sie die native Bibliothek, um sich an verschiedene Plattformen anzupassen. Diese Maßnahmen können es Java -Anwendungen ermöglichen, in verschiedenen Umgebungen am besten zu funktionieren.

Osgi, Apachecommonslang, JNA und JVMOPTIONSAREEFECTIVEFORHANDLATTLATFORM-Spezifikaldesinjava.1) OsgimanagesDependenciesandisolatesComponents.2) apachecommonslangprovidilityfunctions.3) jnaAllowscallingnativeStivingnativeCallingnativeCode

JvmmanagesGecollectionAcrossplattformseffektivyusingagenerationalApproachandaDaptoosandhardwaredFerces

Java -Code kann auf verschiedenen Betriebssystemen ohne Änderung ausgeführt werden, da Javas "einmal schreiben, überall rennen" von Java Virtual Machine (JVM) implementiert wird. Als Vermittler zwischen dem kompilierten Java -Bytecode und dem Betriebssystem übersetzt das JVM die Bytecode in bestimmte Maschinenanweisungen, um sicherzustellen, dass das Programm mit installiertem JVM unabhängig auf jeder Plattform ausführen kann.

Die Zusammenstellung und Ausführung von Java -Programmen erreicht die Unabhängigkeit der Plattform über Bytecode und JVM. 1) Schreiben Sie Java -Quellcode und kompilieren Sie ihn in Bytecode. 2) Verwenden Sie JVM, um Bytecode auf einer beliebigen Plattform auszuführen, um sicherzustellen, dass der Code über Plattformen hinweg ausgeführt wird.


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

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.

SublimeText3 Englische Version
Empfohlen: Win-Version, unterstützt Code-Eingabeaufforderungen!

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor
