suchen
HeimWeb-Frontendjs-TutorialString-Umkehr_JavaScript_Javascript-Tipps

Heute habe ich Fragen auf freeCodeCamp beantwortet und bin auf eine Frage zur String-Umkehr gestoßen. Das Umkehren einer Zeichenfolge ist eine der häufigsten Interviewfragen in JavaScript. Vielleicht gibt Ihnen der Interviewer die Zeichenfolge „Hallo Word!“ und bittet Sie, diese mithilfe von JavaScript in „!droW olleH“ umzuwandeln.

Ich bin auch ein Anfänger und habe den Test mit den zuvor erlernten Array-Kenntnissen bestanden. Später dachte ich: Gibt es andere Möglichkeiten, diese Frage zu lösen? Nach der Suche gibt es noch viele Methoden für die zukünftige Verwendung.

Aktivitäten

Was wir tun müssen:

Um die bereitgestellte Zeichenfolge vor der umgekehrten Zeichenfolge anzuzeigen, müssen Sie die Zeichenfolge in ein Array konvertieren. Das Endergebnis ist immer noch eine Zeichenfolge

Als nächstes werfen wir einen Blick auf einige Methoden, um die oben genannten Anforderungen zu erfüllen.

Eingebaute Funktionen verwenden

In der Übungsfrage werden wir daran erinnert, dass wir drei Methoden verwenden können, um eine Zeichenfolge erfolgreich in umgekehrter Reihenfolge anzuzeigen:

String.prototype.split()Array.prototype.reverse()Array.prototype.join()

Lass es uns kurz durchgehen:

Die Methode „split()“ teilt jedes Zeichen eines Zeichenfolgenobjekts auf und behandelt jede Zeichenfolge als jedes Element des Arrays. Die Methode „reverse()“ wird verwendet, um das Array zu ändern und die Elemente im Array in umgekehrter Reihenfolge anzuordnen Array-Element wird zum letzten und das letzte wird zum ersten. Die Methode join() verbindet alle Elemente im Array zu einer Zeichenfolge

Sehen wir uns ein Beispiel an:

function reverseString(str)
 { // 第一步,使用split()方法,返回一个新数组 
// var splitString = "hello".split(""); 
var splitString = str.split(""); 
//将字符串拆分 // 返回一个新数组["h", "e", "l", "l", "o"] 
// 第二步,使用reverse()方法创建一个新数组 
// var reverseArray = ["h", "e", "l", "l", "o"].reverse(); 
var reverseArray = splitString.reverse(); 
// 原数组元素顺序反转["o", "l", "l", "e", "h"] 
// 第三步,使用join()方法将数组的每个元素连接在一起,组合成一个新字符串 
// var joinArray = ["o", "l", "l", "e", "h"].join(""); 
var joinArray = reverseArray.join(""); // "olleh" 
// 第四步,返回一个反转的新字符串 return joinArray; 
// "olleh"}reverseString("hello"); 
// => olleh

Vereinfachen Sie die obige Methode und schreiben Sie sie wie folgt:

function reverseString(str) {
 return str.split("").reverse().join("");
}reverseString("hello"); 
// => olleh

Kehren Sie die Zeichenfolge mit einem absteigenden Schleifendurchlauf um

Diese Methode verwendet eine for-Schleife, um einen absteigenden Durchlauf der ursprünglichen Zeichenfolge durchzuführen, und kombiniert dann die durchlaufenen Zeichenfolgen erneut zu einer neuen Zeichenfolge:

function reverseString(str) { 
// 第一步:创建一个空的字符串用来存储新创建的字符串 var newString = ""; 
// 第二步:使用for循环 
// 循环从str.length-1开始做递减遍历,直到 i 大于或等于0,循环将继续
 // str.length - 1对应的就是字符串最后一个字符o for (var i = str.length - 1; i >= 0; i--) {
 newString += str[i]; // 或者 newString = newString + str[i]; } 
// 第三步:返回反转的字符串 return newString; }reverseString('hello'); 
// => // "olleh"

Einfacher Blick auf den Prozess der String-Traversierung. Angenommen, Sie müssen die Zeichenfolge „Hallo“ umkehren. Der gesamte Durchlaufvorgang ist in der folgenden Tabelle dargestellt:

Iterationsreihenfolge Der Wert, der i entspricht Neuer String newString Jede Iteration str.length - 1 newString + str[i] Erste Iteration 5 - 1 = 4 "" + "o" = "o" Zweite Iteration 4 - 1 = 3 "o" + "l" = "ol " Dritte Iteration 3 - 1 = 2 "ol" + "l" = "oll" Vierte Iteration 2 - 1 = 1 "oll" + "e" = "olle" Fünfte Iteration Iteration 1 - 1 = 0 "olle" + " h“ = „olleh“

Tatsächlich kann die obige for-Schleife auch durch eine while-Schleife ersetzt werden:

function reverseString (str) {
 var newString = '';
 var i = str.length; while (i > 0) {
 newString += str.substring(i - 1, i);
 i--; 
} 
return newString;}reverseString("hello"); 
// => olleh

while-Methode in der substring()-Schleife. substring() Gibt den Teilstring zwischen zwei Indizes des Strings (oder bis zum Ende des Strings) zurück.

String mit Rekursion umkehren

Eine Zeichenfolge kann auch mit den Methoden String.prototype.substr() und String.prototype.charAt() umgekehrt werden.

Die Methode

substr() gibt den Teilstring beginnend von der angegebenen Position bis zur angegebenen Länge im String zurück. Zum Beispiel:

var str = "abcdefghij";
console.log("(1,2): " + str.substr(1,2));
 // (1,2): bcconsole.log("(-3,2): " + str.substr(-3,2));
 // (-3,2): hiconsole.log("(-3): " + str.substr(-3)); 
// (-3): hijconsole.log("(1): " + str.substr(1)); 
// (1): bcdefghijconsole.log("(-20, 2): " + str.substr(-20,2)); 
// (-20, 2): abconsole.log("(20, 2): " + str.substr(20,2)); 
// (20, 2):
Die Methode

charAt() gibt das Zeichen an der angegebenen Position in der Zeichenfolge zurück. Zeichen in einer Zeichenfolge werden von links nach rechts indiziert, wobei das erste Zeichen den Indexwert 0 und das letzte Zeichen (vorausgesetzt, es befindet sich in der Zeichenfolge stringName) den Indexwert stringName.length - 1 hat. Wenn der angegebene index-Wert außerhalb dieses Bereichs liegt, wird eine leere Zeichenfolge zurückgegeben.

var anyString = "Brave new world";
console.log("The character at index 0 is '" + anyString.charAt(0) + "'"); 
// =>The character at index 0 is 'B'console.log("The character at index 1 is '" + anyString.charAt(1) + "'"); 
// =>The character at index 1 is 'r'console.log("The character at index 2 is '" + anyString.charAt(2) + "'"); 
// =>The character at index 2 is 'a'console.log("The character at index 3 is '" + anyString.charAt(3) + "'"); 
// => The character at index 3 is 'v'console.log("The character at index 4 is '" + anyString.charAt(4) + "'"); 
// => The character at index 4 is 'e'console.log("The character at index 999 is '" + anyString.charAt(999) + "'"); 
// => The character at index 999 is ''

Kombiniert können wir die Zeichenfolgenumkehr wie folgt durchführen:

function reverseString(str) { if (str === "") { 
return ""; } else { 
return reverseString(str.substr(1)) + str.charAt(0); }
}reverseString("hello"); 
// => olleh

Der erste Teil der rekursiven Methode. Sie müssen bedenken, dass Sie es nicht nur einmal aufrufen, sondern mehrere verschachtelte Aufrufe haben.

Jeder Aufruf von str === "?" reverseString(str.subst(1)) + str.charAt(0) Beim ersten Aufruf von reverseString("Hello") reverseString("ello") + "h" Beim zweiten Aufruf von reverseString("ello") reverseString("llo") + "e" Das drittes Mal Aufruf von reverseString("llo") reverseString("lo") + "l" Der vierte Aufruf von reverseString("lo") reverseString("o") + "l" Der fünfte Aufruf von reverseString("o") reverseString(" ") + "o"

Die rekursive Methode im zweiten Teil.

jeden Anruf Geben Sie den fünften Aufruf reverseString("") + "o" = "o" zurück, den vierten Aufruf reverseString("o") + "l" = "o" + "l" den dritten Aufruf reverseString("lo") + "l". " = "o" + "l" + "l" Der zweite Aufruf von reverserString("llo") + "e" = "o" + "l" + "l" + "e" Der erste Aufruf von reverserString("ello ") + "h" = "o" + "l" + "l" + "e" + "h"

Die obige Methode kann weiter verbessert und in den ternären Operator geändert werden

function reverseString(str) { 
return (str === '') ? '' : reverseString(str.substr(1)) + str.charAt(0);}
reverseString("hello"); 
// => olleh

Sie können es auch auf diese Methode ändern

function reverseString(str) { 
return str && reverseString(str.substr(1)) + str[0];
}reverseString("hello");
 // => olleh

Andere Methoden

Zusätzlich zu den oben genannten Methoden gibt es tatsächlich noch einige andere Methoden:

Methode 1

Code kopieren Der Code lautet wie folgt:
function reverseString (str) { var newString = []; for (var i = str.length - 1, j = 0; i >= 0; i--, j++) { newString[j] = str[i]; } return newString.join('');}reverseString("hello"); // => olleh
Méthode 2
Copier le codeLe code est le suivant :
function reverseString (str) { for (var i = str.length - 1, newString = ''; i >= 0; newString += str[i--] ) { } return newString;}reverseString("hello"); // => olleh
Troisième méthode
Copier le codeLe code est le suivant :
function reverseString (str) { function rev(str, len, newString) { return (len === 0) ? newString : rev(str, --len, (newString += str[len])); } return rev(str, str.length, '');}reverseString("hello"); // =>olleh
Méthode quatre
Copier le code Le code est le suivant :
function reverseString (str) { str = str.split(''); var len = str.length, halfIndex = Math.floor(len / 2) - 1, newString; for (var i = 0; i olleh
Méthode 5
Copier le codeLe code est le suivant :
function reverseString (str) { if (str.length olleh
Méthode 6
Copiez le codeLe code est le suivant :
function reverseString(str) { return [].reduceRight.call(str, function(prev, curr) { return prev + curr; }, '');}reverseString("hello"); // =>olleh
Méthode ES6

Dans ES6, cela peut devenir plus simple, comme :

[...str].reverse().join('');

ou [...str].reduceRight( (prev, curr) => prev + curr );

ou :

const reverse = str => str && reverse(str.substr(1)) + str[0];

L'inversion de chaîne est un algorithme petit et simple. Comme mentionné précédemment, il est souvent utilisé dans les entretiens avec les bases de JavaScript. Vous pouvez utiliser différentes méthodes ci-dessus pour résoudre ce problème, ou même utiliser des solutions plus complexes. Si vous avez une meilleure méthode, ajoutez-la dans les commentaires ci-dessous et partagez-la avec nous.

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
Python vs. JavaScript: Die Lernkurve und BenutzerfreundlichkeitPython vs. JavaScript: Die Lernkurve und BenutzerfreundlichkeitApr 16, 2025 am 12:12 AM

Python eignet sich besser für Anfänger mit einer reibungslosen Lernkurve und einer kurzen Syntax. JavaScript ist für die Front-End-Entwicklung mit einer steilen Lernkurve und einer flexiblen Syntax geeignet. 1. Python-Syntax ist intuitiv und für die Entwicklung von Datenwissenschaften und Back-End-Entwicklung geeignet. 2. JavaScript ist flexibel und in Front-End- und serverseitiger Programmierung weit verbreitet.

Python gegen JavaScript: Community, Bibliotheken und RessourcenPython gegen JavaScript: Community, Bibliotheken und RessourcenApr 15, 2025 am 12:16 AM

Python und JavaScript haben ihre eigenen Vor- und Nachteile in Bezug auf Gemeinschaft, Bibliotheken und Ressourcen. 1) Die Python-Community ist freundlich und für Anfänger geeignet, aber die Front-End-Entwicklungsressourcen sind nicht so reich wie JavaScript. 2) Python ist leistungsstark in Bibliotheken für Datenwissenschaft und maschinelles Lernen, während JavaScript in Bibliotheken und Front-End-Entwicklungsbibliotheken und Frameworks besser ist. 3) Beide haben reichhaltige Lernressourcen, aber Python eignet sich zum Beginn der offiziellen Dokumente, während JavaScript mit Mdnwebdocs besser ist. Die Wahl sollte auf Projektbedürfnissen und persönlichen Interessen beruhen.

Von C/C nach JavaScript: Wie alles funktioniertVon C/C nach JavaScript: Wie alles funktioniertApr 14, 2025 am 12:05 AM

Die Verschiebung von C/C zu JavaScript erfordert die Anpassung an dynamische Typisierung, Müllsammlung und asynchrone Programmierung. 1) C/C ist eine statisch typisierte Sprache, die eine manuelle Speicherverwaltung erfordert, während JavaScript dynamisch eingegeben und die Müllsammlung automatisch verarbeitet wird. 2) C/C muss in den Maschinencode kompiliert werden, während JavaScript eine interpretierte Sprache ist. 3) JavaScript führt Konzepte wie Verschlüsse, Prototypketten und Versprechen ein, die die Flexibilität und asynchrone Programmierfunktionen verbessern.

JavaScript -Engines: Implementierungen vergleichenJavaScript -Engines: Implementierungen vergleichenApr 13, 2025 am 12:05 AM

Unterschiedliche JavaScript -Motoren haben unterschiedliche Auswirkungen beim Analysieren und Ausführen von JavaScript -Code, da sich die Implementierungsprinzipien und Optimierungsstrategien jeder Engine unterscheiden. 1. Lexikalanalyse: Quellcode in die lexikalische Einheit umwandeln. 2. Grammatikanalyse: Erzeugen Sie einen abstrakten Syntaxbaum. 3. Optimierung und Kompilierung: Generieren Sie den Maschinencode über den JIT -Compiler. 4. Führen Sie aus: Führen Sie den Maschinencode aus. V8 Engine optimiert durch sofortige Kompilierung und versteckte Klasse.

Jenseits des Browsers: JavaScript in der realen WeltJenseits des Browsers: JavaScript in der realen WeltApr 12, 2025 am 12:06 AM

Zu den Anwendungen von JavaScript in der realen Welt gehören die serverseitige Programmierung, die Entwicklung mobiler Anwendungen und das Internet der Dinge. Die serverseitige Programmierung wird über node.js realisiert, die für die hohe gleichzeitige Anfrageverarbeitung geeignet sind. 2. Die Entwicklung der mobilen Anwendungen erfolgt durch reaktnative und unterstützt die plattformübergreifende Bereitstellung. 3.. Wird für die Steuerung von IoT-Geräten über die Johnny-Five-Bibliothek verwendet, geeignet für Hardware-Interaktion.

Erstellen einer SaaS-Anwendung mit mehreren Mietern mit Next.js (Backend Integration)Erstellen einer SaaS-Anwendung mit mehreren Mietern mit Next.js (Backend Integration)Apr 11, 2025 am 08:23 AM

Ich habe eine funktionale SaaS-Anwendung mit mehreren Mandanten (eine EdTech-App) mit Ihrem täglichen Tech-Tool erstellt und Sie können dasselbe tun. Was ist eine SaaS-Anwendung mit mehreren Mietern? Mit Multi-Tenant-SaaS-Anwendungen können Sie mehrere Kunden aus einem Sing bedienen

So erstellen Sie eine SaaS-Anwendung mit mehreren Mietern mit Next.js (Frontend Integration)So erstellen Sie eine SaaS-Anwendung mit mehreren Mietern mit Next.js (Frontend Integration)Apr 11, 2025 am 08:22 AM

Dieser Artikel zeigt die Frontend -Integration mit einem Backend, das durch die Genehmigung gesichert ist und eine funktionale edtech SaaS -Anwendung unter Verwendung von Next.js. erstellt. Die Frontend erfasst Benutzerberechtigungen zur Steuerung der UI-Sichtbarkeit und stellt sicher, dass API-Anfragen die Rollenbasis einhalten

JavaScript: Erforschung der Vielseitigkeit einer WebspracheJavaScript: Erforschung der Vielseitigkeit einer WebspracheApr 11, 2025 am 12:01 AM

JavaScript ist die Kernsprache der modernen Webentwicklung und wird für seine Vielfalt und Flexibilität häufig verwendet. 1) Front-End-Entwicklung: Erstellen Sie dynamische Webseiten und einseitige Anwendungen durch DOM-Operationen und moderne Rahmenbedingungen (wie React, Vue.js, Angular). 2) Serverseitige Entwicklung: Node.js verwendet ein nicht blockierendes E/A-Modell, um hohe Parallelitäts- und Echtzeitanwendungen zu verarbeiten. 3) Entwicklung von Mobil- und Desktop-Anwendungen: Die plattformübergreifende Entwicklung wird durch reaktnative und elektronen zur Verbesserung der Entwicklungseffizienz realisiert.

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

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)
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
4 Wochen vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

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),

SAP NetWeaver Server-Adapter für Eclipse

SAP NetWeaver Server-Adapter für Eclipse

Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

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.

VSCode Windows 64-Bit-Download

VSCode Windows 64-Bit-Download

Ein kostenloser und leistungsstarker IDE-Editor von Microsoft