suchen

Spiralmatrix IV

Sep 10, 2024 am 06:35 AM

2326. Spiralmatrix IV

Schwierigkeit:Mittel

Themen: Array, verknüpfte Liste, Matrix, Simulation

Sie erhalten zwei ganze Zahlen m und n, die die Dimensionen einer Matrix darstellen.

Sie erhalten außerdem den Kopf einer verknüpften Liste von ganzen Zahlen.

Generieren Sie eine m x n-Matrix, die die ganzen Zahlen in der verknüpften Liste enthält, die in spiralförmiger Reihenfolge (im Uhrzeigersinn) dargestellt werden, beginnend oben links der Matrix . Wenn noch Leerzeichen vorhanden sind, füllen Sie diese mit -1.

Gib die generierte Matrix zurück.

Beispiel 1:

Spiral Matrix IV

  • Eingabe: m = 3, n = 5, Kopf = [3,0,2,6,8,1,7,9,4,2,5,5,0]
  • Ausgabe: [[3,0,2,6,8],[5,0,-1,-1,1],[5,2,4,9,7]]
  • Erklärung:
    • Das obige Diagramm zeigt, wie die Werte in der Matrix gedruckt werden.
    • Beachten Sie, dass die verbleibenden Leerzeichen in der Matrix mit -1 gefüllt werden.

Beispiel 2:

Spiral Matrix IV

  • Eingabe: m = 1, n = 4, Kopf = [0,1,2]
  • Ausgabe: [[0,1,2,-1]]
  • Erklärung:
    • Das Diagramm oben zeigt, wie die Werte von links nach rechts in der Matrix gedruckt werden.
    • Das letzte Leerzeichen in der Matrix wird auf -1 gesetzt.

Beispiel 3:

  • Eingabe: Kosten = [[2, 5, 1], [3, 4, 7], [8, 1, 2], [6, 2, 4], [3, 8, 8] ]
  • Ausgabe: 10

Einschränkungen:

  • 1 5
  • 1 5
  • Die Anzahl der Knoten in der Liste liegt im Bereich [1, m * n].
  • 0

Hinweis:

  1. Generieren Sie zunächst eine mit -1s gefüllte m x n-Matrix.
  2. Navigieren Sie innerhalb der Matrix bei (i, j) mit Hilfe eines Richtungsvektors ⟨di, dj⟩. Bei (i, j) müssen Sie entscheiden, ob Sie in der aktuellen Richtung weitermachen können.
  3. Wenn Sie nicht weitermachen können, drehen Sie den Richtungsvektor um 90 Grad im Uhrzeigersinn.

Lösung:

Wir simulieren eine spiralförmige Durchquerung einer m x n-Matrix und füllen sie mit Werten aus einer verknüpften Liste. Die verbleibenden Positionen, die keine entsprechenden verknüpften Listenwerte haben, werden mit -1 gefüllt.

So ist die Lösung aufgebaut:

  1. Matrix-Initialisierung: Wir erstellen zunächst eine m x n-Matrix, die mit -1 initialisiert wird.
  2. Richtungsvektoren: Die Spiralbewegung kann mithilfe eines Richtungsvektors gesteuert werden, der durch die Richtungen rechts, unten, links und oben wechselt. Dadurch wird sichergestellt, dass wir die Matrix spiralförmig durchlaufen.
  3. Iteration verknüpfter Listen: Wir durchlaufen die verknüpfte Liste und platzieren Werte in spiralförmiger Reihenfolge in der Matrix.
  4. Grenzbehandlung: Wir prüfen, ob wir die Grenze erreicht haben oder auf eine bereits gefüllte Zelle stoßen. Wenn ja, ändern wir die Richtung (im Uhrzeigersinn).

Lassen Sie uns diese Lösung in PHP implementieren: 2326. Spiralmatrix IV

<?php class ListNode {
    public $val = 0;
    public $next = null;
    function __construct($val = 0, $next = null) {
        $this->val = $val;
        $this->next = $next;
    }
}
/**
 * @param Integer $m
 * @param Integer $n
 * @param ListNode $head
 * @return Integer[][]
 */
function spiralMatrix($m, $n, $head) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Helper function to print the matrix (for debugging)
function printMatrix($matrix) {
    foreach ($matrix as $row) {
        echo implode(" ", $row) . "\n";
    }
}

// Example usage:
// Create the linked list: [3,0,2,6,8,1,7,9,4,2,5,5,0]
$head = new ListNode(3);
$head->next = new ListNode(0);
$head->next->next = new ListNode(2);
$head->next->next->next = new ListNode(6);
$head->next->next->next->next = new ListNode(8);
$head->next->next->next->next->next = new ListNode(1);
$head->next->next->next->next->next->next = new ListNode(7);
$head->next->next->next->next->next->next->next = new ListNode(9);
$head->next->next->next->next->next->next->next->next = new ListNode(4);
$head->next->next->next->next->next->next->next->next->next = new ListNode(2);
$head->next->next->next->next->next->next->next->next->next->next = new ListNode(5);
$head->next->next->next->next->next->next->next->next->next->next->next = new ListNode(5);
$head->next->next->next->next->next->next->next->next->next->next->next->next = new ListNode(0);

$m = 3;
$n = 5;

$matrix = spiralMatrix($m, $n, $head);
printMatrix($matrix);
?>

Erläuterung:

  1. Matrix-Initialisierung: Die Matrix wird mit -1 initialisiert, sodass alle nicht ausgefüllten Leerzeichen standardmäßig -1 bleiben.

  2. Spiralbewegung:

    • Der Richtungsvektor dirs verwaltet Bewegungen in vier Richtungen: rechts, unten, links und oben.
    • Der Index dirIndex verfolgt die aktuelle Richtung. Nachdem wir uns in eine Richtung bewegt haben, berechnen wir die nächste Position und prüfen, ob sie gültig ist. Wenn nicht, ändern wir die Richtung.
  3. Verknüpfte Listendurchquerung:

    • Wir durchlaufen die Knoten der verknüpften Liste und platzieren Werte nacheinander in der Matrix, wobei wir der Spiralreihenfolge folgen.
  4. Grenz- und Richtungsänderung:

    • Wenn wir auf eine ungültige Position stoßen (außerhalb der Grenzen oder bereits besetzt), drehen wir die Richtung um 90 Grad (d. h. ändern den Richtungsvektor).

Zeitkomplexität:

  • Das Füllen der Matrix erfordert O(m * n), da wir jede Zelle einmal durchlaufen. Daher beträgt die Zeitkomplexität O(m * n), was angesichts der Einschränkungen effizient ist.

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 vonSpiralmatrix IV. 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
Erläutern Sie das Konzept einer PHP -Sitzung in einfachen Worten.Erläutern Sie das Konzept einer PHP -Sitzung in einfachen Worten.Apr 26, 2025 am 12:09 AM

PhpSessionStrackUserDataacrossMultiplePageRequestsusesuseiquiTIdStoredInacookie.her'ShowtomagetheFectiv: 1) StartaSessionswithSession_start () und storateatain $ _Session.2) regeneratethessionSessionInoginWithSession_IDENT_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTE_IDENTEL

Wie schleifen Sie alle in einer PHP -Sitzung gespeicherten Werte durch?Wie schleifen Sie alle in einer PHP -Sitzung gespeicherten Werte durch?Apr 26, 2025 am 12:06 AM

In PHP können durch Sitzungsdaten in den folgenden Schritten iteriert werden: 1. Starten Sie die Sitzung mit Session_Start (). 2. Iterieren Sie durch die Foreach-Schleife durch alle Schlüsselwertpaare im $ _Session-Array. 3. Wenn Sie komplexe Datenstrukturen verarbeiten, verwenden Sie is_array () oder is_object () Funktionen und verwenden Sie print_r (), um detaillierte Informationen auszugeben. 4. Bei der Optimierung von Traversal kann Paging verwendet werden, um eine gleichzeitige Verarbeitung großer Datenmengen zu vermeiden. Auf diese Weise können Sie PHP -Sitzungsdaten in Ihrem tatsächlichen Projekt effizienter verwalten und verwenden.

Erklären Sie, wie Sie Sitzungen für die Benutzerauthentifizierung verwenden.Erklären Sie, wie Sie Sitzungen für die Benutzerauthentifizierung verwenden.Apr 26, 2025 am 12:04 AM

Die Sitzung realisiert die Benutzerauthentifizierung über den serverseitigen Statusverwaltungsmechanismus. 1) Erstellung der Sitzung und Erzeugung eindeutiger IDs, 2) IDs werden durch Cookies weitergeleitet, 3) Server speichert und greift auf Sitzungsdaten über IDs, 4) Benutzerauthentifizierung und Statusverwaltung zugeordnet und verbessert die Sicherheit und die Benutzererfahrung von Anwendungen.

Geben Sie ein Beispiel dafür, wie Sie den Namen eines Benutzers in einer PHP -Sitzung speichern.Geben Sie ein Beispiel dafür, wie Sie den Namen eines Benutzers in einer PHP -Sitzung speichern.Apr 26, 2025 am 12:03 AM

TostoreaussersnameInaphpSession, startTheSessionwithSession_Start (), thenAnthenameto $ _Session ['Benutzername']

Was sind einige häufige Probleme, die dazu führen können, dass PHP -Sitzungen scheitern?Was sind einige häufige Probleme, die dazu führen können, dass PHP -Sitzungen scheitern?Apr 25, 2025 am 12:16 AM

Gründe für einen Phpessionsfehler sind Konfigurationsfehler, Cookie -Probleme und Sitzungsablauf. 1. Konfigurationsfehler: Überprüfen Sie die richtige Sitzung und setzen Sie die korrekte Sitzung. 2. Kookie -Problem: Stellen Sie sicher, dass der Cookie korrekt eingestellt ist. 3.Sesion läuft ab: Passen Sie die Sitzung an.

Wie debuggen Sie Probleme im Zusammenhang mit Sitzungen in PHP?Wie debuggen Sie Probleme im Zusammenhang mit Sitzungen in PHP?Apr 25, 2025 am 12:12 AM

Zu den Methoden zur Debugg -Sitzungsprobleme in PHP gehören: 1. Überprüfen Sie, ob die Sitzung korrekt gestartet wird. 2. Überprüfen Sie die Lieferung der Sitzungs -ID; 3. Überprüfen Sie den Speicher und das Lesen von Sitzungsdaten. 4. Überprüfen Sie die Serverkonfiguration. Durch Ausgabe von Sitzungs-ID und Daten, Anzeigen von Sitzungsdateiinhalten usw. können Sie effektiv Diagnose und Lösen von Sitzungen im Zusammenhang mit Sitzungen diagnostizieren und lösen.

Was passiert, wenn Session_Start () mehrmals aufgerufen wird?Was passiert, wenn Session_Start () mehrmals aufgerufen wird?Apr 25, 2025 am 12:06 AM

Mehrere Anrufe bei Session_Start () führen zu Warnmeldungen und möglichen Datenüberschreibungen. 1) PHP wird eine Warnung ausstellen und veranlassen, dass die Sitzung gestartet wurde. 2) Dies kann zu unerwarteten Überschreibungen von Sitzungsdaten führen. 3) Verwenden Sie Session_Status (), um den Sitzungsstatus zu überprüfen, um wiederholte Anrufe zu vermeiden.

Wie konfigurieren Sie die Sitzungslebensdauer in PHP?Wie konfigurieren Sie die Sitzungslebensdauer in PHP?Apr 25, 2025 am 12:05 AM

Das Konfigurieren des Sitzungslebenszyklus in PHP kann durch Einstellen von Sitzungen erreicht werden. 1) Session.gc_maxLifetime steuert die Überlebenszeit der serverseitigen Sitzungsdaten, 2) Sitzung.cookie_Lifetime steuert den Lebenszyklus von Client-Cookies. Wenn der Keks auf 0 eingestellt ist, läuft es, wenn der Browser geschlossen ist.

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

Video Face Swap

Video Face Swap

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

Heiße Werkzeuge

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.

Herunterladen der Mac-Version des Atom-Editors

Herunterladen der Mac-Version des Atom-Editors

Der beliebteste Open-Source-Editor

VSCode Windows 64-Bit-Download

VSCode Windows 64-Bit-Download

Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ist eine PHP/MySQL-Webanwendung, die sehr anfällig ist. Seine Hauptziele bestehen darin, Sicherheitsexperten dabei zu helfen, ihre Fähigkeiten und Tools in einem rechtlichen Umfeld zu testen, Webentwicklern dabei zu helfen, den Prozess der Sicherung von Webanwendungen besser zu verstehen, und Lehrern/Schülern dabei zu helfen, in einer Unterrichtsumgebung Webanwendungen zu lehren/lernen Sicherheit. Das Ziel von DVWA besteht darin, einige der häufigsten Web-Schwachstellen über eine einfache und unkomplizierte Benutzeroberfläche mit unterschiedlichen Schwierigkeitsgraden zu üben. Bitte beachten Sie, dass diese Software