2779. Maximale Schönheit eines Arrays nach der Operation
Schwierigkeit:Mittel
Themen:Array, Binäre Suche, Schiebefenster, Sortieren
Sie erhalten eine 0-indizierte Array-Nummer und eine nicht negative ganze Zahl k.
In einem Arbeitsgang können Sie Folgendes tun:
- Wählen Sie einen Index i, der noch nicht ausgewählt wurde aus dem Bereich [0, nums.length - 1].
- Ersetzen Sie nums[i] durch eine beliebige ganze Zahl aus dem Bereich [nums[i] - k, nums[i] k].
Die Schönheit des Arrays ist die Länge der längsten Teilsequenz, die aus gleichen Elementen besteht.
Gibt die maximale mögliche Schönheit der Array-Nummern zurück, nachdem die Operation beliebig oft angewendet wurde.
Beachten Sie, dass Sie den Vorgang nur einmal auf jeden Index anwenden können.
Eine Teilsequenz eines Arrays ist ein neues Array, das aus dem ursprünglichen Array generiert wird, indem einige Elemente (möglicherweise keines) gelöscht werden, ohne die Reihenfolge der verbleibenden Elemente zu ändern.
Beispiel 1:
- Eingabe: nums = [4,6,1,2], k = 2
- Ausgabe: 3
-
Erklärung: In diesem Beispiel wenden wir die folgenden Operationen an:
- Wählen Sie Index 1 und ersetzen Sie ihn durch 4 (aus dem Bereich [4,8]), Nums = [4,4,1,2].
- Wählen Sie Index 3, ersetzen Sie ihn durch 4 (aus dem Bereich [0,4]), Nums = [4,4,1,4].
- Nach den angewendeten Operationen beträgt die Schönheit der Array-Nummern 3 (Teilfolge bestehend aus den Indizes 0, 1 und 3).
- Es kann bewiesen werden, dass 3 die maximal mögliche Länge ist, die wir erreichen können.
Beispiel 2:
- Eingabe: nums = [1,1,1,1], k = 10
- Ausgabe: 4
-
Erklärung: In diesem Beispiel müssen wir keine Operationen anwenden.
- Das Schöne an den Array-Nummern ist 4 (gesamtes Array).
Einschränkungen:
- 1 5
- 0 5
Hinweis:
- Sortieren Sie das Array.
- Das Problem wird wie folgt: Finden Sie das maximale Subarray A[i … j], so dass A[j] - A[i] ≤ 2 * k.
Lösung:
Wir können Sortierung und einen Schiebefenster-Ansatz nutzen.
Ansatz:
- Array sortieren: Das Sortieren vereinfacht die Identifizierung von Teilsequenzen, bei denen die Differenz zwischen dem größten und kleinsten Element 2k nicht überschreitet.
- Schiebefenstertechnik: Pflegen Sie ein Fenster mit Indizes [i, j] wobei die Differenz nums[j] - nums[i] . Passen Sie i oder j an, um die Fenstergröße zu maximieren.
Lassen Sie uns diese Lösung in PHP implementieren: 2779. Maximale Schönheit eines Arrays nach der Operation
<?php /** * @param Integer[] $nums * @param Integer $k * @return Integer */ function maximumBeauty($nums, $k) { ... ... ... /** * go to ./solution.php */ } // Example Usage: $nums1 = [4, 6, 1, 2]; $k1 = 2; echo maximumBeauty($nums1, $k1) . "\n"; // Output: 3 $nums2 = [1, 1, 1, 1]; $k2 = 10; echo maximumBeauty($nums2, $k2) . "\n"; // Output: 4 ?>
Erläuterung:
-
Sortieren des Arrays:
- Sortieren stellt sicher, dass das durch die Indizes [i, j] definierte Fenster alle Elemente in aufsteigender Reihenfolge enthält, was es einfacher macht, den Unterschied zwischen dem kleinsten und dem größten Wert zu überprüfen das Fenster.
-
Schiebefenster:
- Beginnen Sie mit i und j am Anfang.
- Erweitern Sie das Fenster, indem Sie j erhöhen, und halten Sie das Fenster gültig, indem Sie i erhöhen, wann immer die Bedingung nums[j] - nums[i] > 2k wird verletzt.
- Berechnen Sie bei jedem Schritt die Größe des aktuell gültigen Fensters j - i 1 und aktualisieren Sie maxBeauty.
Komplexitätsanalyse:
-
Zeitkomplexität:
- Sortieren des Arrays: O(n log n).
- Durchquerung des Schiebefensters: O(n).
- Insgesamt: O(n log n).
-
Weltraumkomplexität:
- O(1), da die Lösung nur wenige zusätzliche Variablen verwendet.
Beispiele:
Eingabe 1:
$nums = [4, 6, 1, 2]; $k = 2; echo maximumBeauty($nums, $k); // Output: 3
Eingabe 2:
$nums = [1, 1, 1, 1]; $k = 10; echo maximumBeauty($nums, $k); // Output: 4
Diese Lösung hält sich an die Einschränkungen und berechnet das Ergebnis für große Eingaben effizient.
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 vonMaximale Schönheit eines Arrays nach der Operation. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Lange URLs, die oft mit Schlüsselwörtern und Tracking -Parametern überfüllt sind, können Besucher abschrecken. Ein URL -Verkürzungsskript bietet eine Lösung, die präzise Links erstellt, die ideal für soziale Medien und andere Plattformen sind. Diese Skripte sind für einzelne Websites a wertvoll

Laravel vereinfacht die Behandlung von temporären Sitzungsdaten mithilfe seiner intuitiven Flash -Methoden. Dies ist perfekt zum Anzeigen von kurzen Nachrichten, Warnungen oder Benachrichtigungen in Ihrer Anwendung. Die Daten bestehen nur für die nachfolgende Anfrage standardmäßig: $ Anfrage-

Dies ist der zweite und letzte Teil der Serie zum Aufbau einer Reaktionsanwendung mit einem Laravel-Back-End. Im ersten Teil der Serie haben wir eine erholsame API erstellt, die Laravel für eine grundlegende Produktlistenanwendung unter Verwendung von Laravel erstellt hat. In diesem Tutorial werden wir Dev sein

Laravel bietet eine kurze HTTP -Antwortsimulationssyntax und vereinfache HTTP -Interaktionstests. Dieser Ansatz reduziert die Code -Redundanz erheblich, während Ihre Testsimulation intuitiver wird. Die grundlegende Implementierung bietet eine Vielzahl von Verknüpfungen zum Antworttyp: Verwenden Sie Illuminate \ Support \ facades \ http; Http :: fake ([ 'Google.com' => 'Hallo Welt',, 'github.com' => ['foo' => 'bar'], 'Forge.laravel.com' =>

Die PHP Client -URL -Erweiterung (CURL) ist ein leistungsstarkes Tool für Entwickler, das eine nahtlose Interaktion mit Remote -Servern und REST -APIs ermöglicht. Durch die Nutzung von Libcurl, einer angesehenen Bibliothek mit Multi-Protokoll-Dateien, erleichtert PHP Curl effiziente Execu

Möchten Sie den dringlichsten Problemen Ihrer Kunden in Echtzeit und Sofortlösungen anbieten? Mit Live-Chat können Sie Echtzeitgespräche mit Kunden führen und ihre Probleme sofort lösen. Sie ermöglichen es Ihnen, Ihrem Brauch einen schnelleren Service zu bieten

Die 2025 PHP Landscape Survey untersucht die aktuellen PHP -Entwicklungstrends. Es untersucht Framework -Nutzung, Bereitstellungsmethoden und Herausforderungen, die darauf abzielen, Entwicklern und Unternehmen Einblicke zu geben. Die Umfrage erwartet das Wachstum der modernen PHP -Versio

In diesem Artikel werden wir das Benachrichtigungssystem im Laravel -Web -Framework untersuchen. Mit dem Benachrichtigungssystem in Laravel können Sie Benachrichtigungen an Benutzer über verschiedene Kanäle senden. Heute werden wir diskutieren, wie Sie Benachrichtigungen OV senden können


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

Sicherer Prüfungsbrowser
Safe Exam Browser ist eine sichere Browserumgebung für die sichere Teilnahme an Online-Prüfungen. Diese Software verwandelt jeden Computer in einen sicheren Arbeitsplatz. Es kontrolliert den Zugriff auf alle Dienstprogramme und verhindert, dass Schüler nicht autorisierte Ressourcen nutzen.

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

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

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)
