剑指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 ...
随机推荐
- javascript 中的比较大小,兼 typeof()用法
javascript中的排序: 1.不同类型 比 类型 (字符串 > 数字) 2.同类型:(字符串 比 按字母顺序 )(数字 比 大小) 测试: <!DOCTYPE html> ...
- js防抖
那我们设置个 options 作为第三个参数,然后根据传的值判断到底哪种效果,我们约定: leading:false 表示禁用第一次执行trailing: false 表示禁用停止触发的回调 我们来改 ...
- mount、umount、fuser命令使用小结
mount -t cifs -o username=administrator,password=xxxxx //192.168.11.17/Data/ /mnt/databak/之后想卸载挂载目录, ...
- Mybatis中trim的使用
trim标记是一个格式化的标记,可以完成set或者是where标记的功能,如下代码: 1. select * from user <trim prefix="WHERE" p ...
- 完美修改iOS项目名
注意:重命名项目时,记得先备份好一份 1.选中旧项目名,改为新项目名: 选择rename: 2.修改相关文件夹名称: 3.全局搜索旧项目名称,然后替换为新项目名称: 4.经过步骤3的替换,再次全局搜索 ...
- Spring 之通过 XML 装配 bean
1.关于 使用传统标签还是 c- p- 命名空间定义的标签, 我的观点是能用 c- p- 命名空间定义的标签 就不用 传统标签(这样会比较简洁... 2.强依赖使用构造器注入,可选性依赖使用属性注入 ...
- length与size()
List li = new ArrayList(20);System.out.println(li.size()) ;// 0 int [] arr = new int [20];System.ou ...
- zabbix监控nginx的性能
1.nginx配置 需要使用zabbix监控nginx,首先nginx需要配置ngx_status,在nginx的配置文件中加入红框中的配置,然后重启nginx如下图所示: location /ngx ...
- python django model filter 条件过滤,及多表连接查询、反向查询,某字段的distinct[转]
1.多表连接查询:当我知道这点的时候顿时觉得django太NX了. class A(models.Model): name = models.CharField(u'名称') clas ...
- 通俗理解数字签名,数字证书和https
最近在开发关于PDF合同文档电子签章的功能,大概意思就是在一份PDF合同上签名,盖章,使其具有法律效应.签章有法律效应必须满足两个条件: 能够证明签名,盖章者是谁,无法抵赖 PDF合同在签章后不能被更 ...
