前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >合并两个排序的链表

合并两个排序的链表

作者头像
名字是乱打的
发布2022-05-13 09:28:35
7610
发布2022-05-13 09:28:35
举报
文章被收录于专栏:软件工程

题目 :输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。

思想 :类似于排有序数组,,,定义新node/数组.每次遍历将小的放在node/数组中,移动小的node/数组的游标

代码
代码语言:javascript
复制
package com.algorithm.offer;

import com.sun.xml.internal.bind.v2.model.core.ID;

public class Merge {
   static class  ListNode {
        int val;
        ListNode next = null;

        ListNode(int val) {
            this.val = val;
        }
    }

    //输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。
    public  static ListNode Merge(ListNode list1,ListNode list2) {
        if (list1==null){
            return list2;
        }
        if (list2==null){
            return list1;
        }

        ListNode mergeHead =null;
        ListNode curr=null;

        while (list1!=null&&list2!=null){
            if (list1.val<=list2.val){
                if(mergeHead == null){
                    mergeHead = curr = list1;
                }else{
                    curr.next = list1;
                    curr = curr.next;
                }
                list1 = list1.next;
            }else {
                if(mergeHead == null){
                    mergeHead = curr = list2;
                }else{
                    curr.next = list2;
                    curr = curr.next;
                }
                list2 = list2.next;
            }
        }
        if (list1!=null){
            curr.next=list1;
        }else {
            curr.next=list2;
        }
        return mergeHead;
    }

    public static void main(String[] args){
        ListNode l1=new ListNode(1);
        ListNode l2=new ListNode(3);
        ListNode l3=new ListNode(4);
        ListNode l6=new ListNode(5);
        l1.next=l2;
        l2.next=l3;
        l3.next=l6;

        ListNode l4=new ListNode(2);
        ListNode l5=new ListNode(3);
        ListNode l8=new ListNode(3);
        l4.next=l5;
        l5.next=l8;
        ListNode node = Merge(l1, l4);
        while (node!=null){
            System.out.print(node.val+" ");
            node=node.next;
        }
   }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-05-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档