2054. Zwei beste sich nicht überschneidende Events
Schwierigkeit:Mittel
Themen:Array, Binäre Suche, Dynamische Programmierung, Sortierung, Heap (Prioritätswarteschlange)
Sie erhalten ein 0-indiziertes 2D-Integer-Array von Ereignissen, wobei events[i] = [startTimei, endTimei, value ist ich]. Die ite Veranstaltung beginnt bei startTimei und endet bei endTimei, und wenn Sie an dieser Veranstaltung teilnehmen, erhalten Sie einen Wert von valuei . Sie können maximal zwei sich nicht überschneidende Veranstaltungen auswählen, an denen Sie teilnehmen möchten, sodass die Summe ihrer Werte maximiert ist.
Diese maximale Summe zurückgeben.
Beachten Sie, dass die Start- und Endzeit inklusive ist: Das heißt, Sie können nicht an zwei Veranstaltungen teilnehmen, bei denen eine beginnt und die andere gleichzeitig endet. Genauer gesagt: Wenn Sie an einer Veranstaltung mit Endzeit t teilnehmen, muss die nächste Veranstaltung bei oder nach t 1 beginnen.
Beispiel 1:
- Eingabe: Ereignisse = [[1,3,2],[4,5,2],[2,4,3]]
- Ausgabe: 4
- Erklärung:Wählen Sie die grünen Ereignisse 0 und 1 für eine Summe von 2 2 = 4.
Beispiel 2:
- Eingabe: Ereignisse = [[1,3,2],[4,5,2],[1,5,5]]
- Ausgabe: 5
- Erklärung:Wählen Sie Ereignis 2 für eine Summe von 5.
Beispiel 3:
- Eingabe: Ereignisse = [[1,5,3],[1,5,1],[6,6,5]]
- Ausgabe: 8
- Erklärung:Wählen Sie die Ereignisse 0 und 2 für eine Summe von 3 5 = 8.
Einschränkungen:
- 2 5
- events[i].length == 3
- 1 i i 9
- 1 i 6
Hinweis:
- Wie kann es helfen, die Veranstaltungen nach ihren Startzeiten zu sortieren? Wie wäre es mit der Endzeit?
- Wie können wir schnell die maximale Punktzahl eines Intervalls erreichen, das sich nicht mit dem von uns gewählten Intervall überschneidet?
Lösung:
Wir können den folgenden Ansatz verwenden:
Ansatz
-
Ereignisse nach Endzeit sortieren:
- Sortieren hilft uns, mithilfe der binären Suche effizient nicht überlappende Ereignisse zu finden.
-
Binäre Suche nach nicht überlappenden Ereignissen:
- Verwenden Sie die binäre Suche, um das letzte Ereignis zu finden, das vor der Startzeit des aktuellen Ereignisses endet. Dadurch ist eine Überschneidungsfreiheit gewährleistet.
-
Dynamische Programmierung mit Max Tracking:
- Behalten Sie beim Durchlaufen der sortierten Ereignisse den maximalen Wert der Ereignisse bis zum aktuellen bei. Dadurch können wir schnell die maximale Summe zweier Ereignisse berechnen.
-
Iterieren und berechnen Sie die maximale Summe:
- Berechnen Sie für jedes Ereignis die mögliche Summe mit:
- Nur das aktuelle Ereignis.
- Das aktuelle Ereignis kombiniert mit dem besten nicht überlappenden Ereignis, das mithilfe der binären Suche gefunden wurde.
- Berechnen Sie für jedes Ereignis die mögliche Summe mit:
Lassen Sie uns diese Lösung in PHP implementieren: 2054. Zwei beste sich nicht überschneidende Veranstaltungen
<?php /** * @param Integer[][] $events * @return Integer */ function maxTwoEvents($events) { ... ... ... /** * go to ./solution.php */ } // Example Usage: $events1 = [[1, 3, 2], [4, 5, 2], [2, 4, 3]]; $events2 = [[1, 3, 2], [4, 5, 2], [1, 5, 5]]; $events3 = [[1, 5, 3], [1, 5, 1], [6, 6, 5]]; echo maxTwoEvents($events1) . "\n"; // Output: 4 echo maxTwoEvents($events2) . "\n"; // Output: 5 echo maxTwoEvents($events3) . "\n"; // Output: 8 ?>
Erläuterung:
-
Sortieren:
- Die Ereignisse sind nach ihrer Endzeit sortiert, was eine effiziente Suche nach dem letzten sich nicht überschneidenden Ereignis ermöglicht.
-
Binäre Suche:
- Für jedes Ereignis ermittelt die binäre Suche das letzte Ereignis, das endet, bevor das aktuelle Ereignis beginnt.
-
Maximale Nachverfolgung:
- Wir pflegen ein Array maxUpTo, das den Maximalwert von Ereignissen bis zum aktuellen Index speichert. Dadurch wird vermieden, dass das Maximum für frühere Indizes neu berechnet wird.
-
Maximalsummenberechnung:
- Berechnen Sie für jedes Ereignis die Summe seines Werts und des besten nicht überlappenden Ereigniswerts. Aktualisieren Sie die globale Höchstsumme entsprechend.
Komplexitätsanalyse
- Sortierung: O(n log n)
- Binäre Suche nach jedem Ereignis: O(log n), n Mal wiederholt → O(n log n)
- Insgesamt: O(n log n)
Diese Lösung ist effizient und funktioniert gut innerhalb der Einschränkungen.
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 vonZwei beste sich nicht überschneidende Ereignisse. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Die Absolute -Sitzungs -Zeitlimit startet zum Zeitpunkt der Erstellung der Sitzung, während eine Zeitlimit in der Leerlaufsitzung zum Zeitpunkt der No -Operation des Benutzers beginnt. Das Absolute -Sitzungs -Zeitlimit ist für Szenarien geeignet, in denen eine strenge Kontrolle des Sitzungslebenszyklus erforderlich ist, z. B. finanzielle Anwendungen. Das Timeout der Leerlaufsitzung eignet sich für Anwendungen, die die Benutzer für lange Zeit aktiv halten, z. B. soziale Medien.

Der Serversitzungsausfall kann durch Befolgen der Schritte gelöst werden: 1. Überprüfen Sie die Serverkonfiguration, um sicherzustellen, dass die Sitzung korrekt festgelegt wird. 2. Überprüfen Sie die Client -Cookies, bestätigen Sie, dass der Browser es unterstützt und korrekt senden. 3. Überprüfen Sie die Speicherdienste wie Redis, um sicherzustellen, dass sie normal arbeiten. 4. Überprüfen Sie den Anwendungscode, um die korrekte Sitzungslogik sicherzustellen. Durch diese Schritte können Konversationsprobleme effektiv diagnostiziert und repariert werden und die Benutzererfahrung verbessert werden.

Session_Start () iscrucialinphPFormAnagingUSSERSIONS.1) ItinitiatesanewSessionifnoneExists, 2) Wiederaufnahmen und 3) setaSessionCookieforContinuityAcrossRequests, aktivierende Anwendungen wie

Das Festlegen des HTTPonly -Flags ist für Sitzungscookies von entscheidender Bedeutung, da es effektiv verhindern und die Informationen zur Benutzersitzung schützen kann. Insbesondere 1) Das Httponly -Flag verhindert, dass JavaScript auf Cookies zugreift, 2) Das Flag kann durch SetCookies eingestellt werden und in PHP und Flasche 3), obwohl es nicht von allen Angriffen von allen Angriffen verhindert werden kann, Teil der Gesamtsicherheitsrichtlinie sein sollte.

PhpSsionSsionSolvetheProblemofMaintainingStateAcrossmultipehttprequestsBoringDataontheserverandassociatingitittprequests.1) Sie starteten die Stundeataserver-Seite, typischerweise infileSordatabasen, undusaSasionIdinacookookookotenData

PHPSSIONS CANSTORESTRINGEN, ZUGNALTEN, ARRAYS, ANDOBjekte.1.

TostartaphpSession, useSession_start () atthescript'Sbeginning.1) PlaCEITBEFOREANYOUTPUTTOTHESESSIONSCOOKIE.2) useSsionsforuserDatalikeloginStatusOrShopingCarts

Die Sitzung der Sitzung bezieht sich auf die Generierung einer neuen Sitzungs -ID und die Ungültigmachung der alten ID, wenn der Benutzer sensible Vorgänge bei festgelegten Sitzungsangriffen ausführt. Die Implementierungsschritte umfassen: 1. Erkennen sensibler Vorgänge, 2. Erstellen neuer Sitzungs-ID, 3..


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

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

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

SublimeText3 Linux neue Version
SublimeText3 Linux neueste Version

VSCode Windows 64-Bit-Download
Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

SAP NetWeaver Server-Adapter für Eclipse
Integrieren Sie Eclipse mit dem SAP NetWeaver-Anwendungsserver.

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