美文网首页
Java实现两个有序的链表合并

Java实现两个有序的链表合并

作者: 初心myp | 来源:发表于2019-06-13 14:12 被阅读0次

实现两个有序链表的和并,就是将两个链表按照一定的顺序合并成一个链表即可

目标:
单向链表1:SingleLinkedList:[0, 2, 4, 6, 8]
单向链表2:SingleLinkedList:[1, 3, 5, 7, 9, 11]
合并后链表mergedNode:[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 11]

代码实现:

        SingleLinkedList sll1 = new SingleLinkedList();
        for (int i = 0; i < 10; i += 2) {
            SingleNode node = new SingleNode(i, null);
            sll1.add(node);
        }
        System.out.println("单向链表1:" + sll1.toString());

        SingleLinkedList sll2 = new SingleLinkedList();
        for (int i = 1; i < 12; i += 2) {
            SingleNode node = new SingleNode(i, null);
            sll2.add(node);
        }
        System.out.println("单向链表2:" + sll2.toString());
    public SingleNode mergeTwoLists(SingleNode l1, SingleNode l2) {
        if (l1 == null) {
            return l2;
        }
        if (l2 == null) {
            return l1;
        }
        SingleNode mergedNode;
        if (l1.getItem() < l2.getItem()) {
            mergedNode = l1;
            mergedNode.next = mergeTwoLists(l1.next, l2);
        } else {
            mergedNode = l2;
            mergedNode.next = mergeTwoLists(l2.next, l1);
        }
        return mergedNode;
    }

相关文章

  • 合并单链表

    合并两个有序链表非递归实现 合并两个有序链表递归实现

  • 两个有序单链表的合并

    Java实现两个有序单链表的合并 两个有序链表合并时,首先新建一个链表,存储最终的结果。 分情况讨论合并的方式:1...

  • Java实现两个有序的链表合并

    Java实现两个有序的链表合并 先实现两个有序链表 代码如下: 输出:如下所示,跟预期一致。 嵌套调用,完成两个有...

  • leecode刷题(23)-- 合并两个有序链表

    leecode刷题(23)-- 合并两个有序链表 合并两个有序链表 将两个有序链表合并为一个新的有序链表并返回。新...

  • 算法 - 链表实现(OC) 及简单的链表算法

    链表实现 打印链表 链表反转 (使用递归法) 两个有序链表合并为一个有序链表 力扣题[https://leetco...

  • leetcode 链表 [C语言]

    21. 合并两个有序链表 合并两个有序链表 61. 旋转链表 (快慢指针) 61. 旋转链表 相关标签 : 链表 ...

  • ARTS-Week6 有序链表合并、DevOps、Json解析、

    Algorithm LeetCode原题链接: 合并两个有序链表 将两个有序链表合并为一个新的有序链表并返回。新链...

  • leetcode 单链表的各种算法

    1 递归实现:合并两个有序的单链表 2 递归实现:单链表逆序存入vector 3 循环实现:快慢指针找到单链表中间...

  • leetcode的题目21

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

  • 刷leetCode算法题+解析(四)

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

网友评论

      本文标题:Java实现两个有序的链表合并

      本文链接:https://www.haomeiwen.com/subject/mwejfctx.html