首页 > 代码库 > 面试题:合并两个排序的链表
面试题:合并两个排序的链表
题目:输入两个递增排序的链表,合并这两个链表并使新链表中的节点仍然是递增的。
例如:
/*合并两个排序的链表*/ /* 链表节点定义如下: 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
面试题:合并两个排序的链表
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。