Inhaltsverzeichnis
Methode
Beispiel
In diesem Beispiel ist das Ergebnis 4, was nach 2 Drehungen bei Index 3 liegt. " >In diesem Beispiel ist das Ergebnis 4, was nach 2 Drehungen bei Index 3 liegt.
Anleitung
Heim Web-Frontend js-Tutorial JavaScript-Programm zum Suchen eines Elements an einem bestimmten Index nach mehreren Rotationen

JavaScript-Programm zum Suchen eines Elements an einem bestimmten Index nach mehreren Rotationen

Aug 26, 2023 am 09:25 AM

JavaScript 程序在多次旋转后查找给定索引处的元素

Wir werden ein JavaScript-Programm implementieren, um das Element nach mehreren Rotationen an einem bestimmten Index zu finden. Dieses Programm fordert uns auf, eine Drehung des Arrays durchzuführen und dann das am angegebenen Index vorhandene Element zurückzugeben. Um diese Aufgabe zu erfüllen, verwenden wir den Modulo-Operator, um den neuen Index nach jeder Drehung zu berechnen. In der gesamten Erklärung wird die Zukunftsform verwendet.

Im Programm erhalten wir die Eingabe, die Anzahl der Drehungen und den Index des Arrays. Anschließend führen wir Drehungen mit dem Modulo-Operator durch, um nach jeder Drehung den neuen Index zu finden. Der neue Index wird gefunden, indem die Anzahl der Umdrehungen zum ursprünglichen Index addiert wird und dann die Summe modulo zur Array-Länge genommen wird. Das Element am Endindex wird als Ergebnis des Programms zurückgegeben.

Zusammenfassend werden wir ein einfaches, aber effizientes Programm entwickeln, um das Element an einem bestimmten Index nach mehreren Rotationen zu finden. Dieses Programm demonstriert die Verwendung des Modulo-Operators und ist ein wertvolles Werkzeug für alle, die Array-Rotationen in JavaScript durchführen möchten.

Methode

Bei einem Array von Elementen und mehreren Drehungen k besteht die Aufgabe darin, das Element am angegebenen Index n nach den Drehungen zu finden.

  • Bestimmen Sie zunächst die tatsächliche Position des Elements nach k Umdrehungen. Die tatsächliche Position kann durch Modulo n und k ermittelt werden.

  • Führt eine Drehung des Arrays durch, indem die Elemente k Mal nach rechts verschoben werden.

  • Um eine Rotation zu erreichen, können wir die folgende Methode verwenden:

    • Speichern Sie das letzte Element in einer temporären Variablen.

    • Verschieben Sie alle Elemente einen Schritt nach rechts.

    • Ersetzen Sie das erste Element durch eine temporäre Variable.

  • Wiederholen Sie Schritt 3 k Mal, um alle Drehungen abzuschließen.

  • Nachdem alle Drehungen abgeschlossen sind, geben Sie das Element am nten Index zurück, der nun die tatsächliche Position ist.

  • Die zeitliche Komplexität dieser Methode beträgt O(n * k), , wobei n die Anzahl der Elemente im Array ist. Dies kann jedoch mithilfe des Konzepts der zyklischen Rotation auf O(n) optimiert werden.

Beispiel

Dies ist ein JavaScript-Programm, das das Element nach mehreren Rotationen an einem bestimmten Index findet -

function findElement(arr, rotations, index) {
   // Number of rotations modulo length of the array
   rotations = rotations % arr.length;
     
   // New index after rotations
   let newIndex = (arr.length + index - rotations) % arr.length;
    
   // Return element at new index
   return arr[newIndex];
}
let arr = [1, 2, 3, 4, 5];
let rotations = 2;
let index = 4;
console.log(findElement(arr, rotations, index)); // Output: 3
Nach dem Login kopieren

In diesem Beispiel ist das Ergebnis 4, was nach 2 Drehungen bei Index 3 liegt.

Anleitung

  • Die Funktion findElement benötigt drei Parameter: arr, rotation und index. arr ist das Array von Elementen, Rotationen sind die Anzahl der Rotationen, die auf dem Array ausgeführt werden sollen, und Index ist der Index des Elements, das nach den Rotationen gefunden werden soll.

  • Die erste Zeile der Funktion
  • berechnet die Anzahl der Drehungen modulo zur Länge des Arrays. Dies geschieht, weil, wenn die Anzahl der Drehungen größer als die Länge des Arrays ist, das Array nach einigen Drehungen in seinen ursprünglichen Zustand zurückkehrt. Daher müssen wir nur eine Drehung durchführen, die der Länge des Arrays entspricht.

  • Die nächste Zeile berechnet den neuen Index des Elements nach der Drehung. Dazu wird die Anzahl der Umdrehungen vom angegebenen Index subtrahiert und die Länge des Arrays zum Ergebnis addiert. Der letzte Schritt besteht darin, das Ergebnis modulo zur Array-Länge zu berechnen.

  • Abschließend gibt die Funktion das Element am neuen Index zurück.

  • Im folgenden Code initialisieren wir das Array arr, die Anzahl der Umdrehungen und den Index index

  • Die letzte Codezeile ruft die Funktion findElement auf und gibt die Ergebnisse auf der Konsole aus.

Das obige ist der detaillierte Inhalt vonJavaScript-Programm zum Suchen eines Elements an einem bestimmten Index nach mehreren Rotationen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
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

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

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie erstelle ich meine eigenen JavaScript -Bibliotheken? Wie erstelle ich meine eigenen JavaScript -Bibliotheken? Mar 18, 2025 pm 03:12 PM

In Artikel werden JavaScript -Bibliotheken erstellt, veröffentlicht und aufrechterhalten und konzentriert sich auf Planung, Entwicklung, Testen, Dokumentation und Werbestrategien.

Wie optimiere ich den JavaScript -Code für die Leistung im Browser? Wie optimiere ich den JavaScript -Code für die Leistung im Browser? Mar 18, 2025 pm 03:14 PM

In dem Artikel werden Strategien zur Optimierung der JavaScript -Leistung in Browsern erörtert, wobei der Schwerpunkt auf die Reduzierung der Ausführungszeit und die Minimierung der Auswirkungen auf die Lastgeschwindigkeit der Seite wird.

Was soll ich tun, wenn ich auf den Codendruck auf Kleidungsstücke für Front-End-Thermalpapier-Quittungen stoße? Was soll ich tun, wenn ich auf den Codendruck auf Kleidungsstücke für Front-End-Thermalpapier-Quittungen stoße? Apr 04, 2025 pm 02:42 PM

Häufig gestellte Fragen und Lösungen für das Ticket-Ticket-Ticket-Ticket in Front-End im Front-End-Entwicklungsdruck ist der Ticketdruck eine häufige Voraussetzung. Viele Entwickler implementieren jedoch ...

Wie debugge ich den JavaScript -Code effektiv mithilfe von Browser -Entwickler -Tools? Wie debugge ich den JavaScript -Code effektiv mithilfe von Browser -Entwickler -Tools? Mar 18, 2025 pm 03:16 PM

In dem Artikel werden effektives JavaScript -Debuggen mithilfe von Browser -Entwickler -Tools, der Schwerpunkt auf dem Festlegen von Haltepunkten, der Konsole und der Analyse der Leistung erörtert.

Wer bekommt mehr Python oder JavaScript bezahlt? Wer bekommt mehr Python oder JavaScript bezahlt? Apr 04, 2025 am 12:09 AM

Es gibt kein absolutes Gehalt für Python- und JavaScript -Entwickler, je nach Fähigkeiten und Branchenbedürfnissen. 1. Python kann mehr in Datenwissenschaft und maschinellem Lernen bezahlt werden. 2. JavaScript hat eine große Nachfrage in der Entwicklung von Front-End- und Full-Stack-Entwicklung, und sein Gehalt ist auch beträchtlich. 3. Einflussfaktoren umfassen Erfahrung, geografische Standort, Unternehmensgröße und spezifische Fähigkeiten.

Wie verwende ich Quellkarten zum Debuggen, um den JavaScript -Code zu debuggen? Wie verwende ich Quellkarten zum Debuggen, um den JavaScript -Code zu debuggen? Mar 18, 2025 pm 03:17 PM

In dem Artikel wird erläutert, wie Quellkarten zum Debuggen von JavaScript verwendet werden, indem er auf den ursprünglichen Code zurückgegeben wird. Es wird erläutert, dass Quellenkarten aktiviert, Breakpoints eingestellt und Tools wie Chrome Devtools und WebPack verwendet werden.

Wie fusioniere ich Arrayelemente mit derselben ID mit JavaScript in ein Objekt? Wie fusioniere ich Arrayelemente mit derselben ID mit JavaScript in ein Objekt? Apr 04, 2025 pm 05:09 PM

Wie fusioniere ich Array -Elemente mit derselben ID in ein Objekt in JavaScript? Bei der Verarbeitung von Daten begegnen wir häufig die Notwendigkeit, dieselbe ID zu haben ...

Der Unterschied in der Konsole.log -Ausgabeergebnis: Warum unterscheiden sich die beiden Anrufe? Der Unterschied in der Konsole.log -Ausgabeergebnis: Warum unterscheiden sich die beiden Anrufe? Apr 04, 2025 pm 05:12 PM

Eingehende Diskussion der Ursachen des Unterschieds in der Konsole.log-Ausgabe. In diesem Artikel wird die Unterschiede in den Ausgabeergebnissen der Konsolenfunktion in einem Code analysiert und die Gründe dafür erläutert. � ...

See all articles