题解 | #合并两个排序的链表#

合并两个排序的链表

https://www.nowcoder.com/practice/d8b6b4358f774294a89de2a6ac4d9337

import java.util.*;

/*
 * public class ListNode {
 *   int val;
 *   ListNode next = null;
 *   public ListNode(int val) {
 *     this.val = val;
 *   }
 * }
 */

public class Solution {
    /**
     * 思路:不断遍历两个链表,同时比较val大小
     *		值小的节点的接到新链表的后面,不断循环,直到有一个链表到头,值为null
     * 		比较一轮后如果还有链表不是空,可以直接把他接到此时新链表的后面
	 *		返回存储的新链表的头节点即可
	 *
     * @param pHead1 ListNode类 
     * @param pHead2 ListNode类 
     * @return ListNode类
     */
    public ListNode Merge (ListNode pHead1, ListNode pHead2) {
        ListNode s = new ListNode(-1);//用来找到新链表头节点
        ListNode p = s;
        ListNode p1 = pHead1;
        ListNode p2 = pHead2;
        while(p1 != null && p2 != null){
		  //比较
            if(p1.val > p2.val){
                p.next = p2;
                p2 = p2.next;
            }else{
                p.next = p1;
                p1 = p1.next;
            }
            p = p.next;
        }
	  //不为空的接到新链表后面
        if(p1 != null){
            p.next = p1;
        }
        if(p2 != null){
            p.next = p2;
        }
        return s.next;
    }
}

全部评论

相关推荐

1 收藏 评论
分享
牛客网
牛客企业服务