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

合并两个排序的链表

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 pHead2 == nil {
		return pHead1
	}
	if pHead1 == nil {
		return pHead2
	}
	
	// 记录最小值节点,以及需要返回的节点
	minHead := &ListNode{}
	resHead := minHead

	// 对比大小,不断修改指向
	for pHead1 != nil && pHead2 != nil {
		if pHead1.Val > pHead2.Val {
			minHead.Next = pHead2
			pHead2 = pHead2.Next
		} else {
			minHead.Next = pHead1
			pHead1 = pHead1.Next
		}
		minHead = minHead.Next
	}

	// 拼接剩下的
	if pHead1 != nil {
		minHead.Next = pHead1
	} else {
		minHead.Next = pHead2
	}

	// 遍历完成,返回
	return resHead.Next
}

全部评论

相关推荐

自学java狠狠赚一...:骗你点star的,港卵公司,记得把star收回去
点赞 评论 收藏
分享
门口唉提是地铁杀:之前b站被一个游戏demo深深的吸引了。看up主页发现是个初创公司,而且还在招人,也是一天60。二面的时候要我做一个登录验证和传输文件两个微服务,做完要我推到github仓库,还要我加上jaeger和一堆运维工具做性能测试并且面试的时候投屏演示。我傻乎乎的做完以后人家跟我说一句现在暂时不招人,1分钱没拿到全是白干
你的秋招第一场笔试是哪家
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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