Leetcode基础刷题之PHP解析(21. Merge Two Sorted Lists)

栏目: PHP · 发布时间: 6年前

内容简介:2019-6-28 星期五 开始吧又到了思考人生的周末了

2019-6-28 星期五 开始吧

又到了思考人生的周末了 Leetcode基础刷题之 <a href='https://www.codercto.com/topics/18749.html'>PHP</a> 解析(21. Merge Two Sorted Lists)

Leetcode基础刷题之PHP解析(19. Remove Nth Node From End of List)

Leetcode基础刷题之PHP解析(21. Merge Two Sorted Lists)

给定两个单链表,让我们从小到大把两个单链表合并成一个链表。

很常规的思路就是每次比较两个链表的头指针的值,谁小谁进入新的链表,然后指针指向它的next位置。好像不用新建链表?每次对比一下它两的大小,假设我们最终返回的链表当前的头指针的值大于另一个链表头指针的值,那么就互换他两,这样就确保了每次返回链表的顺序都是有序的。实现的时候用递归即可。

  /**
     * @param ListNode $l1
     * @param ListNode $l2
     * @return ListNode
     */
    function mergeTwoLists($l1, $l2) {

        if($l1 !==null && $l2 !==null){
            if($l1->val > $l2->val){
                $temp=$l1;
                $l1=$l2;
                $l2=$temp;
            }
            $l1->next=$this->mergeTwoLists($l1->next,$l2);
           
        }
         return $l1??$l2;
    }

换一种思路

  /**
     * @param ListNode $l1
     * @param ListNode $l2
     * @return ListNode
     */
    function mergeTwoLists($l1, $l2) {
        if($l1 ==null) return $l2;
        if($l2 ==null) return $l1;
        
        if($l1->val < $l2->val){
            $l1->next=$this->mergeTwoLists($l1->next,$l2);
            return $l1;
        }else{
            $l2->next=$this->mergeTwoLists($l2->next,$l1);
            return $l2;
        }
    }

Github整理地址 : https://github.com/wuqinqiang/leetcode-php


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

大连接

大连接

[美] 尼古拉斯•克里斯塔基斯(Nicholas A. Christakis)、[美] 詹姆斯•富勒(James H. Fowler) / 简学 / 中国人民大学出版社 / 2013-1 / 59.90元

[内容简介] 1. 本书是继《六度分隔》之后,社会科学领域最重要的作品。作者发现:相距三度之内是强连接,强连接可以引发行为;相聚超过三度是弱连接,弱连接只能传递信息。 2. 本书讲述了社会网络是如何形成的以及对人类现实行为的影响,如对人类的情绪、亲密关系、健康、经济的运行和政治的影响等,并特别指出,三度影响力(即朋友的朋友的朋友也能影响到你)是社会化网络的强连接原则,决定着社会化网络的......一起来看看 《大连接》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具