美文网首页PHP开发PHP经验分享
PHP-几行代码翻转链表

PHP-几行代码翻转链表

作者: 简单方式 | 来源:发表于2020-03-12 17:30 被阅读0次
几行代码翻转链表

声明结构

class node
{
    public $val;
    public $next;

    public function __construct($val)
    {
        $this->val = $val;
    }
}


$head                   = new node(1);
$head->next             = new node(2);
$head->next->next       = new node(3);
$head->next->next->next = new node(4);

输出

node Object
(
    [val] => 1
    [next] => node Object
        (
            [val] => 2
            [next] => node Object
                (
                    [val] => 3
                    [next] => node Object
                        (
                            [val] => 4
                            [next] => 
                        )

                )

        )

)

第一种翻转方式 (递归)

function reNode($head)
{
   if (!$head->next) {
       return $head;
   }

   $prevNode         = reNode($head->next);
   $head->next->next = $head;
   $head->next       = null;

   return $prevNode;
}

print_r(reNode($head));

第二种翻转方式 (循环)

function reNode($head) {
    while ($head) {
        $tmpNode    = $head->next;
        $head->next = empty($newHead) ? null : $newHead;
        $newHead    = $head;
        $head       = $tmpNode;
    }
    return $newHead;
}

print_r(reNode($head));

输出

node Object
(
    [val] => 4
    [next] => node Object
        (
            [val] => 3
            [next] => node Object
                (
                    [val] => 2
                    [next] => node Object
                        (
                            [val] => 1
                            [next] => 
                        )

                )

        )

)

相关文章

  • PHP-几行代码翻转链表

    声明结构 输出 第一种翻转方式 (递归) 第二种翻转方式 (循环) 输出

  • 单向链表反转(含图解)

    前言 上次讲解了单向链表的原理《Java实现单向链表功能》,今天拓展一下实现链表的翻转。下面直接上代码。 链表初始...

  • LeetCode25 K个一组翻转链表(Java实现)

    LeetCode25 K个一组翻转链表(Java实现) 题目描述: 代码:

  • 翻转链表

    翻转链表 描述翻转一个链表 样例给出一个链表1->2->3->null,这个翻转后的链表为3->2->1->nul...

  • LintCode 翻转链表 II

    题目 翻转链表中第m个节点到第n个节点的部分 注意事项m,n满足1 ≤ m ≤ n ≤ 链表长度 代码

  • 25. K 个一组翻转链表

    K个一组反转链表 翻转链表给你一个链表,每 k 个节点一组进行翻转,请你返回翻转后的链表。 k 是一个正整数,它...

  • 链表翻转

    给定单向链表,返回翻转后的链表

  • 链表

    1.翻转链表链表的定义 翻转 快慢指针找链表 的中间位置 3.有序链表的合并 4.判断链表中是否有环解法1: 借助...

  • Swift - LeetCode - 翻转链表

    题目 翻转链表 问题: 翻转链表中第m个节点到第n个节点的部分 说明: m,n满足1 ≤ m ≤ n ≤ 链表长度...

  • K 个一组翻转链表(递归,Kotlin)

    25. K 个一组翻转链表 给你一个链表,每 k 个节点一组进行翻转,请你返回翻转后的链表。 k 是一个正整数,它...

网友评论

    本文标题:PHP-几行代码翻转链表

    本文链接:https://www.haomeiwen.com/subject/nqnmjhtx.html