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

合并两个排序的链表

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

package main
import . "nc_tools"
/*
 * type ListNode struct{
 *   Val int
 *   Next *ListNode
 * }
 */

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

    if pHead2 == nil {
        return pHead1
    }

    if pHead1.Val < pHead2.Val {
        pHead1.Next = Merge(pHead1.Next,pHead2)
        return pHead1
    }else {
        pHead2.Next = Merge(pHead1,pHead2.Next)
        return pHead2
    }

}


func Merge( pHead1 *ListNode ,  pHead2 *ListNode ) *ListNode {
    
    if pHead1 == nil {
        return pHead2
    }
    if pHead2 == nil {
        return pHead1
    }
    vh := &ListNode{}
    cur := vh
    for i := 0;;i++ {
        if (pHead1 == nil || pHead2 == nil) {
            break
        }
        if pHead1.Val < pHead2.Val {
            cur.Next = pHead1
            pHead1 = pHead1.Next
        }else {
            cur.Next = pHead2
            pHead2 = pHead2.Next
        }
        cur = cur.Next
    }

    if pHead1 != nil {
        cur.Next = pHead1
    }

    if pHead2 != nil {
        cur.Next = pHead2
    }
    return vh.Next
}

全部评论
递归 YYDS
点赞 回复 分享
发布于 2023-10-21 22:23 上海

相关推荐

11-06 16:50
门头沟学院 Java
用微笑面对困难:word打字比赛二等奖的我,也要来凑合凑合
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务