博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
leetcode21 Merge Two Sorted Lists 将两个有序链表组合成一个新的有序链表
阅读量:5815 次
发布时间:2019-06-18

本文共 1691 字,大约阅读时间需要 5 分钟。

题目要求

Merge two sorted linked lists and return it as a new list. The new list should be made by splicing together the nodes of the first two lists.

翻译过来就是:将两个有序的链表组合成一个新的有序的链表

思路一:循环

在当前两个链表的节点都是非空的情况下比较大小,较小的添入结果链表中并且获得较小节点的下一个节点。这样比较直至至少遍历完一个链表。再将剩下的链表添至结果链表的末端

public class MergeTwoSortedLists_21 {    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {        ListNode start = new ListNode(0);        ListNode temp = new ListNode(0);        start.next = temp;        while(l1!=null && l2!=null){            if(l1.val <= l2.val){                temp.next = l1;                l1 = l1.next;            }else{                temp.next = l2;                l2 = l2.next;            }            temp = temp.next;        }        if(l1!=null){            temp.next = l1;        }        if(l2!=null){            temp.next = l2;        }        return start.next.next;    }        public class ListNode{        int val;        ListNode next;        ListNode(int x) { val = x; }    }}

思路二:递归

每次比较得到两个节点中较小的节点作为结果返回,并继续对剩下来的链表重新获得较小节点。

public class MergeTwoSortedLists_21 {    public ListNode mergeTwoLists_recursive(ListNode l1, ListNode l2){        if(l1==null){            return l2;        }else if (l2==null){            return l1;        }        ListNode mergeHead;        if(l1.val <= l2.val){            mergeHead = l1;            mergeHead.next = mergeTwoLists_recursive(l1.next, l2);        }else{            mergeHead = l2;            mergeHead.next = mergeTwoLists(l1, l2.next);        }        return mergeHead;    }        public class ListNode{        int val;        ListNode next;        ListNode(int x) { val = x; }    }}

clipboard.png

想要了解更多开发技术,面试教程以及互联网公司内推,欢迎关注我的微信公众号!将会不定期的发放福利哦~

转载地址:http://rdqbx.baihongyu.com/

你可能感兴趣的文章
实战Django:小型CMS Part2
查看>>
原创]windows server 2012 AD架构试验系列 – 16更改DC计算机名
查看>>
统治世界的十大算法
查看>>
linux svn安装和配置
查看>>
SSH中调用另一action的方法(chain,redirect)
查看>>
数据库基础
查看>>
表格排序
查看>>
关于Android四大组件的学习总结
查看>>
java只能的round,ceil,floor方法的使用
查看>>
由于无法创建应用程序域,因此未能执行请求。错误: 0x80070002 系统找不到指定的文件...
查看>>
新开的博客,为自己祝贺一下
查看>>
puppet任务计划
查看>>
【CQOI2011】放棋子
查看>>
采用JXL包进行EXCEL数据写入操作
查看>>
一周总结
查看>>
将txt文件转化为json进行操作
查看>>
线性表4 - 数据结构和算法09
查看>>
C语言数据类型char
查看>>
Online Patching--EBS R12.2最大的改进
查看>>
Binary Search Tree Iterator leetcode
查看>>