Maison >développement back-end >tutoriel php >PHP implémente l'ordre inverse de la liste chaînée

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

不言
不言original
2018-04-19 15:19:411576parcourir

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);
} ?>

<.>

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!

Déclaration:
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