剑指Offer面试题:13.合并两个排序的链表
一 题目:合并两个排序的链表
题目:输入两个递增排序的链表,合并这两个链表并使新链表中的结点仍然是按照递增排序的。例如输入下图中的链表1和链表2,则合并之后的升序链表如链表3所示。
二 代码实现
template <typename T>
struct Node
{
public:
T data;
Node *pNext;
}; template <typename T>
class ListEx
{
private:
Node<T> *m_pHead;
Node<T> *m_pTail;
public:
ListEx()
{
m_pTail = m_pHead = NULL;
}
~ListEx()
{
Node<T> *pTemp = NULL;
Node<T> *pNode = m_pHead;
while (pNode)
{
pTemp = pNode;
pNode = pNode->pNext;
delete pTemp;
} m_pHead = m_pTail = NULL;
}
void add(T data)
{
Node<T> *pNode = new Node<T>;
pNode->data = data;
pNode->pNext = NULL; if (m_pHead == NULL)
{
m_pTail = m_pHead = pNode;
} Node<T>* pTemp = m_pTail;
pTemp->pNext = pNode;
m_pTail = pNode;
} Node<T> *GetListHead()
{
return m_pHead;
}
};
template <typename T>
Node<T>* RebuildArray(Node<T>* pNode1, Node<T>* pNode2)
{
if (NULL == pNode1)
{
return pNode2;
}
else if (NULL == pNode2)
{
return pNode1;
}
Node<T>* pNewNode = new Node<T>;
pNewNode = NULL;
if (pNode1->data <= pNode2->data)
{
pNewNode = pNode1;
pNewNode->pNext = RebuildArray(pNode1->pNext, pNode2);
}
else
{
pNewNode = pNode2;
pNewNode->pNext = RebuildArray(pNode1, pNode2->pNext);
} return pNewNode;
}
void main()
{
ListEx<int> *pList1= new ListEx<int>();
pList1->add();
pList1->add();
pList1->add();
pList1->add();
Node<int> *pHead1 = pList1->GetListHead(); ListEx<int> *pList2= new ListEx<int>();
pList2->add();
pList2->add();
pList2->add();
pList2->add();
Node<int> *pHead2 = pList2->GetListHead(); Node<int>* p = RebuildArray(pHead1, pHead2);
}
将链表换成数组做简单的循环和递归测试
(1)循环实现
void RebuildArray(int *a, int nLen1, int *b, int nLen2, int *pNew)
{
if (NULL == a || NULL == b || == nLen1 || == nLen2 || NULL == pNew)
{
return;
} int nIndex = ;
int i = ;
int j = ;
while (i < nLen1)
{
while (j < nLen2)
{
if (a[i] <= b[j])
{
pNew[nIndex++] = a[i++];
break;
}
else
{
pNew[nIndex++] = b[j++];
}
}
}
while(i < nLen1)
{
pNew[nIndex++] = a[i++];
}
while(j < nLen2)
{
pNew[nIndex++] = b[j++];
}
}
(2)递归实现
void RebuildArray_2(int *aStart, int *aEnd, int *bStart, int *bEnd, int *pNew)
{
if (aStart > aEnd)
{
*pNew = *bStart;
return;
}
else if (bStart > bEnd)
{
*pNew = *aStart;
return;
}
if (*aStart <= *bStart)
{
*pNew = *aStart;
RebuildArray_2(aStart+, aEnd, bStart, bEnd, pNew+);
}
else
{
*pNew = *bStart;
RebuildArray_2(aStart, aEnd, bStart+, bEnd, pNew+);
}
}
void RebuildArray_1(int *a, int nLen1, int *b, int nLen2, int *pNew)
{
if (NULL == a || NULL == b || == nLen1 || == nLen2 || NULL == pNew)
{
return;
} int *aStart = a;
int *aEnd = &a[nLen1 - ];
int *bStart = b;
int *bEnd = &b[nLen2 - ]; RebuildArray_2(aStart, aEnd, bStart, bEnd, pNew);
}
剑指Offer面试题:13.合并两个排序的链表的更多相关文章
- 剑指Offer:面试题17——合并两个排序的链表
题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 思路1: 分别用p1,p2两个指针扫描两个有序链表,p3指针去构建新链表h3. p1.val & ...
- 剑指Offer - 九度1519 - 合并两个排序的链表
剑指Offer - 九度1519 - 合并两个排序的链表2013-11-30 22:04 题目描述: 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则.(hi ...
- 剑指offer十六之合并两个排序的链表
一.题目 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 二.思路 注:链表1和链表2是两个递增排序的链表,合并这两个链表得到升序链表为链表3. 首先分析 ...
- 【剑指Offer】16、合并两个排序的链表
题目描述: 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 解题思路: 首先需要判断几个特殊情况,即判断输入的两个指针是否为空.如果第一个 ...
- 剑指offer(16)合并两个排序的链表
题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 题目分析 重点抓住这两个链表都是单挑递增的,因此我们只需要不断地比较他们的头结点就行,明显这是个 ...
- 剑指Offer:面试题13——在O(1)时间删除链表结点
问题描述: 给定单向链表的头指针和一个结点指针,定义一个函数在O(1)时间删除该结点.链表结点与函数的定义如下: public class ListNode{ int value; ListNode ...
- 【剑指offer】面试题 25. 合并两个排序的链表
面试题 25. 合并两个排序的链表 NowCoder 题目描述 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. Java 实现 ListNode Clas ...
- 【剑指Offer面试题】 九度OJ1518:反转链表
与其非常快写出一段漏洞百出的代码,倒不如细致分析再写出鲁棒的代码. 提前想好測试用例(输入非空等等)进行測试改动代码. 题目链接地址: http://ac.jobdu.com/problem.php? ...
- C++版 - 剑指offer之面试题37:两个链表的第一个公共结点[LeetCode 160] 解题报告
剑指offer之面试题37 两个链表的第一个公共结点 提交网址: http://www.nowcoder.com/practice/6ab1d9a29e88450685099d45c9e31e46?t ...
随机推荐
- 跟着实例学习ZooKeeper的用法: 分布式锁
锁 分布式的锁全局同步, 这意味着任何一个时间点不会有两个客户端都拥有相同的锁. 可重入锁Shared Reentrant Lock 首先我们先看一个全局可重入的锁. Shared意味着锁是全局可见的 ...
- 如何选择单片机和Android-LInux-ARM开发板?
源: 如何选择单片机和Android-LInux-ARM开发板?
- 详解Linux系统下PXE服务器的部署过程
在大规模安装服务器时,需要批量自动化方法来安装服务器,来减少日常的工作量. 但是批量自动化安装服务器的基础是网络启动服务器(bootserver). 下面我们就介绍一下 网络启动服务器的 安装和配置方 ...
- docker 使用mysql
mysql 5.7安装成功了,之前5.6一直报错不知道为什么 sudo docker run --name emall_mysql -e MYSQL_ROOT_PASSWORD=jbt1234 -e ...
- javascript页面打印
打印本身比较简单,但要考虑到具体的需求.比如 1. 多浏览器: if (isIE()) { //打印预览 WebBrowser1.execWB(7, 1); } else { window.print ...
- GridView右键菜单
一.添加右键菜单 1.在VS工具箱中的“菜单和工具栏”找到ContextMenuStrip控件,双击添加. 2.点击ContextMenuStrip右上方的小三角形,打开编辑项,可以添加菜单项.至于菜 ...
- java sleep()和wait()的区别
java sleep()和wait()的区别? sleep()和wait()都能阻塞当前线程. 区别1: sleep()属于Thread类:wait()属于Object类. 区别2: 调用sleep( ...
- shell awk使用(转)
#####awk " 对每一行操作的代码块" 操作的文件 awk -F: '{print $1,$2,$3,$4,$5}' helloworld.sh 打印字段 ...
- kindeditor上传本地图片实例
所需插件:kindeditor下载 密码: 5ry4 jsp文件: <script type="text/javascript" language="javas ...
- Win7 SP1 下安装 VS2015 Update 3
首先Win7必须是SP1,然后要求安装IE11,安装IE11前需要安装6个先决补丁,成功安装IE11后建议安装3个可选补丁.然后导入3个根证书(COMODO RSA Certification Aut ...
