PHP implémente l'ordre inverse de la liste chaînée

不言
Libérer: 2023-03-24 12:32:02
original
1505 Les gens l'ont consulté

Le contenu de cet article concerne la mise en œuvre de l'ordre inversé des listes chaînées en PHP. Il a une certaine valeur de référence. Maintenant, je le partage avec tout le monde. Les amis dans le besoin peuvent s'y référer

<?php
    class Node {
        public $str;        public $next;        function __construct ($str) {
            $this->str = $str;
        }
    }    //创建链表头
    function createList () {
        $head = new Node(null);        return $head;
    }    //向链表$head中插入节点并赋值
    function insertNode ($str, &$head) {
        $node = new Node($str);        $node->next = &$head->next;        $head->next = &$node;
    }    //取出链表的第一个节点,相当于出队
    function outQueue (&$head) {
        $tmp = $head->next;        $head->next = $head->next->next;        $tmp->next = null;        return $tmp;
    }    //将链表$head进行逆序
    function reverse (&$head) {
        $reversed = createList(null);        while (null != $head->next) {
            insertNode(outQueue($head), $reversed);
        }        return $reversed;
    }    $head = createList();
    insertNode(&#39;hello&#39;, $head);
    insertNode(&#39;world&#39;, $head);
    insertNode(&#39;99999999999999&#39;, $head);
    insertNode(&#39;888888888888888&#39;, $head);
    insertNode(&#39;7777777777777&#39;, $head);
    insertNode(&#39;66666666666666&#39;, $head);
    insertNode(&#39;55555555555&#39;, $head);
    insertNode(&#39;444444444444&#39;, $head);
    insertNode(&#39;333333333333&#39;, $head);
    insertNode(&#39;222222222222222&#39;, $head);
    insertNode(&#39;111111111111&#39;, $head);
    insertNode(&#39;000000000000000&#39;, $head);
    print_r($head);    $reversed = reverse($head);    echo "<hr />";
    print_r($reversed);    //上面的方法没有在原链表上操作,不过他创建了一个新链表,
    //虽然逻辑实现显得简单,但是太不专业
    //下面贴出更加专业的逆序代码
    function reverse2 (&$head) {
    $q = $head->next->next;    $head->next->next = null;    while (null != $q) {        $p = $q;        $q = $p->next;        $p->next = $head->next;        $head->next = $p;
    }
    reverse2($head);    echo "<hr />";
    print_r($head);
} ?>
Copier après la connexion

<.>

Résultat de sortie :

Liste chaînée avant l'ordre inverse :
Objet nœud ( [str] => [suivant] => Objet nœud ( [str] => 000000000000000 [suivant ] => Objet nœud ( [str] => 111111111111 [suivant] => Objet nœud ( [str] => 22222222222222 [suivant] => Objet nœud ( [str] => 333333333333 [suivant] => Objet nœud ( [ str] => ] => 444444444444 [suivant] => Objet nœud ( [str] => 55555555555 [suivant] => Objet nœud ( [str] => 66666666666666 [suivant] => > 777777777777 7 [suivant] => Objet nœud ( [str] => 888888888888888 [suivant] => Objet nœud ( [str] => 999999999999999 [suivant] => Objet nœud ( [str] => monde [suivant ] => Objet nœud ( [str] => bonjour [suivant] => ) ) ) ) ) ) ) ) ) ) ) )

Liste chaînée inversée :

Objet nœud ( [ str] => [suivant] => Objet nœud ( [str] => Objet nœud ( [str] => bonjour [suivant] => ) [suivant] => Objet nœud ( [str] = > Objet nœud ( [str] => monde [suivant] => ) [suivant] => Objet nœud ( [str] => Objet nœud ( [str] => 99999999999999 [suivant] ] => ; ) [suivant] => Objet nœud ( [str] => Objet nœud ( [str] => 888888888888888 [suivant] => ) [suivant] => Objet nœud ( [str] = > Nœud Objet ( [str] => 7777777777777 [suivant] => ) [suivant] => Objet nœud ( [str] => Objet nœud ( [str] => 66666666666666 [suivant] => ) [suivant ] => Objet nœud ( [str] => Objet nœud ( [str] => 55555555555 [suivant] => ) [suivant] => Objet nœud ( [str] => Objet nœud ( [str ] => 444444444444 [suivant] => ) [suivant] => Objet nœud ( [str] => Objet nœud ( [str] => 333333333333 [suivant] => ) [suivant] => Objet nœud ( [str] => Objet nœud ( [str] => 222222222222222 [suivant] => ) [suivant] => Objet nœud ( [str] => Objet nœud ( [str] => 111111111111 [suivant] => ) [suivant] => Objet nœud ( [str] => Objet nœud ( [str] => 000000000000000 [suivant] => ) [suivant] => ) ) ) ) ) ) ) ) ) ) ) ) )

Recommandations associées :

Utiliser PHP pour implémenter une liste à chaînage unique

Comment implémentez-le en PHP Liste doublement chaînée et tri


Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!