LeetCode题目-21

首页 编程分享 LEET_CODE 正文

leetCode 转载 编程分享 2019-10-08 05:51:42

简介 LeetCode题目-21


✏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;
         }
     }

转载链接:https://leetcode.cn/


Tags:


本篇评论 —— 揽流光,涤眉霜,清露烈酒一口话苍茫。


    声明:参照站内规则,不文明言论将会删除,谢谢合作。


      最新评论




ABOUT ME

Blogger:袅袅牧童 | Arkin

Ido:PHP攻城狮

WeChat:nnmutong

Email:nnmutong@icloud.com

标签云