1475. Endgültige Preise mit Sonderrabatt in einem Geschäft
Schwierigkeit:Einfach
Themen: Array, Stack, Monotoner Stack
Sie erhalten ein ganzzahliges Array „Preise“, wobei „Preise[i]“ der Preis des itenArtikels in einem Geschäft ist.
Es gibt einen Sonderrabatt auf Artikel im Shop. Wenn Sie den iten Artikel kaufen, erhalten Sie einen Rabatt, der den Preisen[j] entspricht, wobei j der Mindestindex ist, sodass j > i und Preise[j]
Gibt eine Ganzzahl-Array-Antwort zurück, wobei Antwort[i] der Endpreis ist, den Sie für den itenArtikel im Shop zahlen, unter Berücksichtigung des Sonderrabatts.
Beispiel 1:
- Eingabe: Preise = [8,4,6,2,3]
- Ausgabe: [4,2,4,2,3]
-
Erklärung:
- Für Artikel 0 mit Preis[0]=8 erhalten Sie einen Rabatt entsprechend den Preisen[1]=4, daher beträgt der Endpreis, den Sie zahlen müssen, 8 - 4 = 4.
- Für Artikel 1 mit Preis[1]=4 erhalten Sie einen Rabatt entsprechend den Preisen[3]=2, daher beträgt der Endpreis, den Sie zahlen müssen, 4 - 2 = 2.
- Für Artikel 2 mit Preis[2]=6 erhalten Sie einen Rabatt in Höhe von Preisen[3]=2, daher beträgt der Endpreis, den Sie zahlen müssen, 6 - 2 = 4.
- Für die Artikel 3 und 4 erhalten Sie überhaupt keinen Rabatt.
Beispiel 2:
- Eingabe: Preise = [1,2,3,4,5]
- Ausgabe: [1,2,3,4,5]
- Erklärung:In diesem Fall erhalten Sie für alle Artikel überhaupt keinen Rabatt.
Beispiel 3:
- Eingabe: Preise = [10,1,1,6]
- Ausgabe: [9,0,1,6]
Einschränkungen:
- 1
- 1
Hinweis:
- Wenden Sie rohe Gewalt an: Suchen Sie für den i-ten Artikel im Shop mit einer Schleife die erste Position j, die die Bedingungen erfüllt, und wenden Sie den Rabatt an, andernfalls beträgt der Rabatt 0.
Lösung:
Wir müssen einen speziellen Rabatt gewähren, der auf der Bedingung basiert, dass es einen späteren Artikel mit einem Preis gibt, der kleiner oder gleich dem aktuellen Preis ist. Wir können einen Brute-Force-Ansatz verwenden. Wir durchlaufen das Preisarray und suchen für jeden Artikel nach dem ersten Artikel mit einem niedrigeren oder gleichen Preis danach. Dies kann mit verschachtelten Schleifen erreicht werden. Wir können einen Stapel verwenden, um die Preise der Artikel effizient zu verfolgen und den Sonderrabatt anzuwenden.
Ansatz:
-
Stack-Ansatz:
- Wir können das Preisarray von links nach rechts durchlaufen. Für jeden Artikel verwenden wir den Stapel, um die Preise zu verfolgen, für die noch kein Rabatt gefunden wurde.
- Für jeden Preis prüfen wir, ob er kleiner oder gleich dem Preis oben im Stapel ist. Wenn ja, bedeutet das, dass wir einen Rabatt gewähren können.
- Der Stapel speichert die Indizes der Artikel und wir prüfen für jeden Artikel, ob der aktuelle Preis höher ist als der Preis am Index im Stapel, was bedeutet, dass es keinen Rabatt gibt. Andernfalls wenden Sie den Rabatt an, indem Sie den entsprechenden Preis vom aktuellen Preis abziehen.
Edge Case: Wenn später in der Reihe kein Artikel einen niedrigeren Preis hat, wird kein Rabatt gewährt.
Lassen Sie uns diese Lösung in PHP implementieren: 1475. Endgültige Preise mit Sonderrabatt in einem Geschäft
<?php /** * @param Integer[] $prices * @return Integer[] */ function finalPrices($prices) { ... ... ... /** * go to ./solution.php */ } // Example usage: $prices1 = [8, 4, 6, 2, 3]; $prices2 = [1, 2, 3, 4, 5]; $prices3 = [10, 1, 1, 6]; print_r(finalPrices($prices1)); // Output: [4, 2, 4, 2, 3] print_r(finalPrices($prices2)); // Output: [1, 2, 3, 4, 5] print_r(finalPrices($prices3)); // Output: [9, 0, 1, 6] ?>
Erläuterung:
-
Initialisierung:
- Erstellen Sie ein Array $result mit der gleichen Größe wie $prices und initialisieren Sie es auf 0.
-
Äußere Schleife:
- Durchlaufen Sie jeden Preis bei Index $i, um seinen Endpreis nach Rabatten zu berechnen.
-
Innere Schleife:
- Iterieren Sie für jeden Preis $i die nachfolgenden Preise $j (wobei $j > $i).
- Überprüfen Sie, ob $prices[$j] kleiner oder gleich $prices[$i] ist. Wenn wahr, setzen Sie $discount = $prices[$j] und verlassen Sie die innere Schleife.
-
Endgültige Preisberechnung:
- Subtrahieren Sie den gefundenen Rabatt von $prices[$i] und speichern Sie das Ergebnis in $result[$i].
-
Ergebnis zurückgeben:
- Nachdem alle Preise verarbeitet wurden, geben Sie das endgültige Ergebnisarray zurück.
Komplexität:
- Zeitkomplexität: O(n²) (aufgrund der verschachtelten Schleifen für jeden Preis).
- Raumkomplexität: O(n) (für das Ergebnisarray).
Beispielausgaben:
- Für Preise = [8, 4, 6, 2, 3] ist die Ausgabe [4, 2, 4, 2, 3].
- Für Preise = [1, 2, 3, 4, 5] ist die Ausgabe [1, 2, 3, 4, 5].
- Für Preise = [10, 1, 1, 6] ist die Ausgabe [9, 0, 1, 6].
Dieser Ansatz funktioniert innerhalb der Einschränkungen des Problems (1
Kontaktlinks
Wenn Sie diese Serie hilfreich fanden, denken Sie bitte darüber nach, dem Repository einen Stern auf GitHub zu geben oder den Beitrag in Ihren bevorzugten sozialen Netzwerken zu teilen? Ihre Unterstützung würde mir sehr viel bedeuten!
Wenn Sie weitere hilfreiche Inhalte wie diesen wünschen, folgen Sie mir gerne:
- GitHub
Das obige ist der detaillierte Inhalt vonEndgültige Preise mit Sonderrabatt in einem Geschäft. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

PHP ist hauptsächlich prozedurale Programmierung, unterstützt aber auch die objektorientierte Programmierung (OOP). Python unterstützt eine Vielzahl von Paradigmen, einschließlich OOP, funktionaler und prozeduraler Programmierung. PHP ist für die Webentwicklung geeignet, und Python eignet sich für eine Vielzahl von Anwendungen wie Datenanalyse und maschinelles Lernen.

PHP entstand 1994 und wurde von Rasmuslerdorf entwickelt. Es wurde ursprünglich verwendet, um Website-Besucher zu verfolgen und sich nach und nach zu einer serverseitigen Skriptsprache entwickelt und in der Webentwicklung häufig verwendet. Python wurde Ende der 1980er Jahre von Guidovan Rossum entwickelt und erstmals 1991 veröffentlicht. Es betont die Lesbarkeit und Einfachheit der Code und ist für wissenschaftliche Computer, Datenanalysen und andere Bereiche geeignet.

PHP eignet sich für Webentwicklung und schnelles Prototyping, und Python eignet sich für Datenwissenschaft und maschinelles Lernen. 1.PHP wird für die dynamische Webentwicklung verwendet, mit einfacher Syntax und für schnelle Entwicklung geeignet. 2. Python hat eine kurze Syntax, ist für mehrere Felder geeignet und ein starkes Bibliotheksökosystem.

PHP bleibt im Modernisierungsprozess wichtig, da es eine große Anzahl von Websites und Anwendungen unterstützt und sich den Entwicklungsbedürfnissen durch Frameworks anpasst. 1.PHP7 verbessert die Leistung und führt neue Funktionen ein. 2. Moderne Frameworks wie Laravel, Symfony und Codesigniter vereinfachen die Entwicklung und verbessern die Codequalität. 3.. Leistungsoptimierung und Best Practices verbessern die Anwendungseffizienz weiter.

PhPhas significantantyPactedWebDevelopmentAndendendsbeyondit.1) iTpowersMAjorPlatforms-LikewordpressandExcelsInDatabaseInteractions.2) php'SadaptabilityAllowStoscaleForLargeApplicationsfraMe-Linien-Linien-Linien-Linienkripte

PHP -Typ -Eingabeaufforderungen zur Verbesserung der Codequalität und der Lesbarkeit. 1) Tipps zum Skalartyp: Da Php7.0 in den Funktionsparametern wie int, float usw. angegeben werden dürfen. 3) Eingabeaufforderung für Gewerkschaftstyp: Da Php8.0 in Funktionsparametern oder Rückgabetypen angegeben werden dürfen. 4) Nullierstyp Eingabeaufforderung: Ermöglicht die Einbeziehung von Nullwerten und Handlungsfunktionen, die Nullwerte zurückgeben können.

Verwenden Sie in PHP das Klonschlüsselwort, um eine Kopie des Objekts zu erstellen und das Klonierungsverhalten über die \ _ \ _ Clone Magic -Methode anzupassen. 1. Verwenden Sie das Klonschlüsselwort, um eine flache Kopie zu erstellen und die Eigenschaften des Objekts, nicht die Eigenschaften des Objekts zu klonen. 2. Die \ _ \ _ Klonmethode kann verschachtelte Objekte tief kopieren, um flache Kopierprobleme zu vermeiden. 3. achten Sie darauf, dass kreisförmige Referenzen und Leistungsprobleme beim Klonen vermieden werden, und optimieren Sie die Klonierungsvorgänge, um die Effizienz zu verbessern.

PHP eignet sich für Webentwicklungs- und Content -Management -Systeme, und Python eignet sich für Datenwissenschafts-, maschinelles Lernen- und Automatisierungsskripte. 1.PHP hat eine gute Leistung beim Erstellen von schnellen und skalierbaren Websites und Anwendungen und wird üblicherweise in CMS wie WordPress verwendet. 2. Python hat sich in den Bereichen Datenwissenschaft und maschinelles Lernen mit reichen Bibliotheken wie Numpy und TensorFlow übertrifft.


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

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

SecLists
SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

Dreamweaver CS6
Visuelle Webentwicklungstools

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung