码迷,mamicode.com
首页 > 编程语言 > 详细

面试题:合并两个排序的链表

时间:2016-10-22 00:51:22      阅读:202      评论:0      收藏:0      [点我收藏+]

标签:链表

题目:输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增的。


例如:

技术分享

/*合并两个排序的链表*/

/*
链表节点定义如下:

struct ListNode
{
int _data;
ListNode* _next;
};

*/
ListNode* MergeList(ListNode* pHead1, ListNode* pHead2)
{
	if (pHead1 == NULL) //链表1为空链表
	{
		return pHead2;
	}
	else if (pHead2 == NULL) // 链表2为空链表
	{
		return pHead1;
	}
	else //链表1,2都不为空链表
	{
		ListNode* pMergeHead = NULL;

		//递归,把剩余链表看作子问题
		//找出值较小的节点作为pMergeHead链到上一层的pMergeHead->_next上
		if (pHead1->_data < pHead2->_data)
		{
			pMergeHead = pHead1;
			pMergeHead->_next = MergeList(pHead1->_next, pHead2);
		}
		else
		{
			pMergeHead = pHead2;
			pMergeHead->_next = MergeList(pHead1, pHead2->_next);
		}

		return pMergeHead;
	}
}


本文出自 “zgw285763054” 博客,请务必保留此出处http://zgw285763054.blog.51cto.com/11591804/1864429

面试题:合并两个排序的链表

标签:链表

原文地址:http://zgw285763054.blog.51cto.com/11591804/1864429

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!