suchen
HeimBackend-EntwicklungPHP-TutorialEndgültige Preise mit Sonderrabatt in einem Geschäft

Final Prices With a Special Discount in a Shop

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:

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

  1. 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.
  2. 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:

  1. Initialisierung:

    • Erstellen Sie ein Array $result mit der gleichen Größe wie $prices und initialisieren Sie es auf 0.
  2. Äußere Schleife:

    • Durchlaufen Sie jeden Preis bei Index $i, um seinen Endpreis nach Rabatten zu berechnen.
  3. 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.
  4. Endgültige Preisberechnung:

    • Subtrahieren Sie den gefundenen Rabatt von $prices[$i] und speichern Sie das Ergebnis in $result[$i].
  5. 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:

  • LinkedIn
  • 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!

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
PHP und Python: Verschiedene Paradigmen erklärtPHP und Python: Verschiedene Paradigmen erklärtApr 18, 2025 am 12:26 AM

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 und Python: Ein tiefes Eintauchen in ihre GeschichtePHP und Python: Ein tiefes Eintauchen in ihre GeschichteApr 18, 2025 am 12:25 AM

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.

Wählen Sie zwischen PHP und Python: Ein LeitfadenWählen Sie zwischen PHP und Python: Ein LeitfadenApr 18, 2025 am 12:24 AM

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 und Frameworks: Modernisierung der SprachePHP und Frameworks: Modernisierung der SpracheApr 18, 2025 am 12:14 AM

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.

Auswirkungen von PHP: Webentwicklung und darüber hinausAuswirkungen von PHP: Webentwicklung und darüber hinausApr 18, 2025 am 12:10 AM

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

Wie funktioniert der Php -Typ -Hinweis, einschließlich Skalartypen, Rückgabetypen, Gewerkschaftstypen und nullbaren Typen?Wie funktioniert der Php -Typ -Hinweis, einschließlich Skalartypen, Rückgabetypen, Gewerkschaftstypen und nullbaren Typen?Apr 17, 2025 am 12:25 AM

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.

Wie handelt es sich bei PHP -Objektklonen (Klonschlüsselwort) und der __clone Magic -Methode?Wie handelt es sich bei PHP -Objektklonen (Klonschlüsselwort) und der __clone Magic -Methode?Apr 17, 2025 am 12:24 AM

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 vs. Python: Anwendungsfälle und AnwendungenPHP vs. Python: Anwendungsfälle und AnwendungenApr 17, 2025 am 12:23 AM

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.

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)
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌
Will R.E.P.O. Crossplay haben?
1 Monate vorBy尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

SecLists

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

Dreamweaver CS6

Visuelle Webentwicklungstools

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Leistungsstarke integrierte PHP-Entwicklungsumgebung