package main
/*
 * type ListNode struct{
 *   Val int
 *   Next *ListNode
 * }
 */

/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param pHead1 ListNode类 
 * @param pHead2 ListNode类 
 * @return ListNode类
*/
func Merge( pHead1 *ListNode ,  pHead2 *ListNode ) *ListNode {
    // write code here
    if pHead1 == nil {
        return pHead2
    }
    if pHead2 == nil {
        return pHead1
    }
    var ans *ListNode = nil
    if pHead1.Val < pHead2.Val {
        ans = pHead1
        ans.Next = Merge(ans.Next, pHead2)
    } else {
        ans = pHead2
        ans.Next = Merge(pHead1, ans.Next)
    }
    return ans
}