合并两个有序链表

将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。

示例:

输入:1->2->4, 1->3->4
输出:1->1->2->3->4->4

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/merge-two-sorted-lists
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) { val = x; }
 * }
 */
class Solution {
    public ListNode mergeTwoLists(ListNode l1, ListNode l2) {
        ListNode node=new ListNode(0);
        ListNode node1=node;
        while (l1!=null||l2!=null){
            if(l1==null||l2==null){
                if(l2!=null){
                    node1.next=l2;
                    l2=l2.next;
                    node1=node1.next;
                }else if(l1!=null){
                    node1.next=l1;
                    l1=l1.next;
                    node1=node1.next;
                }
            }else {
                if(l1.val>l2.val){
                    node1.next=l2;
                    l2=l2.next;
                    node1=node1.next;
                }else {
                    node1.next=l1;
                    l1=l1.next;
                    node1=node1.next;
                }
            }
        }
        return node.next;
    }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 21. 合并两个有序链表 将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成...
    TheKey_阅读 4,225评论 0 1
  • 题目 将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例: 输入:...
    禾木清清阅读 910评论 0 0
  • /** 将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例: 输入...
    iamlyly阅读 4,117评论 0 0
  • [TOC] 题目 将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示...
    吉祥鸟hu阅读 11,075评论 0 0
  • 将两个有序链表合并为一个新的有序链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 示例: 输入:1->...
    FiveZM阅读 2,828评论 0 0