合并两个有序链表

合并两个有序链表

    public Node mergeNode(Node node1,Node node2){
        //严谨判断 没有严谨判断不得分
        if (node1 == null) return node2;
        if (node2 == null) return node1;
        Node result = null;//头结点
        // 找到两个链表的 头结点 比较那个小 小的那个变成新的头结点
        if (node1.value <= node2.value){
            result = node1;
            node1 = node1.next;
        }else {
            result = node2;
            node2 = node2.next;
        }
        //尾结点
        Node tail = result;
        // 如果两个 链表null时证明 两个链表都合并成了 result链表中
        while(node1 != null || node2 != null){
            //  node2 == null 条件满足 直接将node1的value复制到tail后面
            //  node2 == null 不满足时 需要判断node1是否为null  如果不等于null 两个node比较大小按顺序复制到tail中
            //                              node1为null是直接将node2的值复制到tail中
            if (node2 == null || node1 != null && node1.value <= node2.value){
                tail.next = node1;
                tail = tail.next;
                node1 = node1.next;
            }else {
                tail.next = node2;
                tail = tail.next;
                node2 = node2.next;
            }
        }
        return result;
    }

    public static void main(String[] args) {
        Test t = new Test();
        Node a1 = new Node(1);
        Node a2 = new Node(2);
        Node a3 = new Node(3);
        Node a4 = new Node(4);
        Node a5 = new Node(5);
        a1.next = a2;
        a2.next = a3;
        a3.next = a4;
        a4.next = a5;
        Node b1 = new Node(1);
        Node b2 = new Node(2);
        Node b3 = new Node(3);
        Node b4 = new Node(4);
        Node b5 = new Node(5);
        b1.next = b2;
        b2.next = b3;
        b3.next = b4;
        b4.next = b5;
        Node result = t.mergeNode(a1,b1);//1 1 2 2 3 3 4 4 5 5 
        
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值