内容简介:2019-6-28 星期五 开始吧又到了思考人生的周末了
2019-6-28 星期五 开始吧
又到了思考人生的周末了
上 一 题 链 接 Leetcode基础刷题之PHP解析(19. Remove Nth Node From End of List)
题 目 描 述
给定两个单链表,让我们从小到大把两个单链表合并成一个链表。
题 目 分 析
很常规的思路就是每次比较两个链表的头指针的值,谁小谁进入新的链表,然后指针指向它的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
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- Apache Flink 零基础入门(一):基础概念解析
- Apache Flink 零基础入门(一):基础概念解析
- JStorm 源码解析:基础线程模型
- React Hooks 解析(上):基础
- TypeScript基础入门之模块解析(一)
- TypeScript基础入门之模块解析(二)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
PHP高级程序设计
Kevin McArthur / 汪泳 等 / 人民邮电出版社出版 / 2009.7 / 45.00元
今天,PHP已经是无可争议的Web开发主流语言。PHP 5以后,它的面向对象特性也足以与Java和C#相抗衡。然而,讲述PHP高级特性的资料一直缺乏,大大影响了PHP语言的深入应用。 本书填补了这一空白。它专门针对有一定经验的PHP程序员,详细讲解了对他们最为重要的主题:高级面向对象、设计模式、文档、测试和标准PHP库等内容。同时,为适应目前Web开发的新趋势,作者还全面探讨了MVC架构和Z......一起来看看 《PHP高级程序设计》 这本书的介绍吧!