美文网首页
两种方式翻转链表

两种方式翻转链表

作者: spurYin | 来源:发表于2017-05-07 23:45 被阅读0次
<?php 
class LinkList
{
    public $val;
    public $nextLink;//下一个节点
    public function __construct($val){
        $this->val=$val;
    }
    
    function appendToTail($i){
        $newLink=new LinkList($i);
        $current=$this;
        while($current->nextLink != null){
            $current=$current->nextLink;
        }
        $current->nextLink=$newLink;
    }
}
class LinkListTest
{
    /**
    *翻转链表
    **/
    function reverseLink($link){
        //需要3个指针
        //$l1,$l2,$l3;
        if($link == null || $link->nextLink == null){
            return $link;
        }
        $l1=null;
        $l2=$link;
        while($l2 != null){
            $l3=$l2->nextLink;//先把p2的下一个节点保存起来
            $l2->nextLink=$l1;//翻转p1、p2,p2的下一个节点指向p1
            //向后移动p1,p2,p3节点
            $l1=$l2;//p1向后移动到p2
            $l2=$l3;//p2向后移动到原来的p2->nextLink
        }
        return $l1;//返回原来的表尾,现在是表头
    }
    /**
    *递归实现
    *翻转链表
    */
    function reverseLink1($link)
    {
        if($link == null || $link->nextLink == null){
            return $link;
        }
        $l1=$link->nextLink;
        $link->nextLink=null;
        $revLink=$this->reverseLink1($l1);
        $l1->nextLink=$link;
        return $revLink;
    }
    //打印链表
    function printLink($link){
        while($link != null){
            echo $link->val."->";
            $link=$link->nextLink;
        }
    }
}

$list3=new LinkList(1);
$list3->appendToTail(2);
$list3->appendToTail(3);
$list3->appendToTail(2);
$list3->appendToTail(5);
$ll= new LinkListTest;
$ll->printLink($ll->reverseLink($list3));
$ll->printLink($ll->reverseLink1($list3));

相关文章

  • 两种方式翻转链表

  • 链表反转

    参考文献链表翻转的图文讲解(递归与迭代两种实现)

  • 链表翻转的图文讲解(递归与迭代两种实现)

    转载 链表翻转的图文讲解(递归与迭代两种实现) 链表的翻转是程序员面试中出现频度最高的问题之一,常见的解决方法分为...

  • 翻转链表

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

  • 链表翻转的图文讲解(递归与迭代两种实现)

    链表的翻转是程序员面试中出现频度最高的问题之一,常见的解决方法分为递归和迭代两种。 1、非递归(迭代)方式 迭代的...

  • 25. K 个一组翻转链表

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

  • 链表翻转

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

  • 链表

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

  • 反转链表(java实现)

    链表反转 节点数据结构如下: 链表反转的两种方式:递归和非递归 递归方式如下: 非递归方式如下:

  • Swift - LeetCode - 翻转链表

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

网友评论

      本文标题:两种方式翻转链表

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