剑指offer—第三章高质量代码(合并两个排序链表)
题目:输入员两个递增排序的链表,合并这两个链表并使新的链表中的结点仍然是按照递增排序的。
思路:首先,定义两个头节点分别为Head1和Head2的链表,然后比较第一个节点的值,如果是Head1->mValue比Head2->mValue小,那么头节点,就是Head1,递归实现后面的节点的排序。
C++代码:
#include<iostream>
using namespace std;
struct ListNode
{
int m_nValue;
ListNode* m_pNext;
};
ListNode* CreateList(int a[],int b)
{ ListNode* pHead=NULL,*pNode=NULL;
for(int i=;i<b;i++)
{
ListNode* pNew=new ListNode();
pNew->m_nValue=a[i];
pNew->m_pNext=NULL;
if(pHead==NULL)
{
pHead=pNew;
pNode=pNew; }
else
{
pNode->m_pNext=pNew;
pNode=pNode->m_pNext;
}
}
return pHead;
}
void PrintList(ListNode* pHead)
{
if(pHead==NULL)
{
return;
}
ListNode* pNode=pHead;
while(pNode!=NULL)
{
cout<<pNode->m_nValue<<" ";
pNode=pNode->m_pNext; }
cout<<endl;
}
ListNode* MergeLink(ListNode* Head1,ListNode* Head2)
{
ListNode* MergeHead=NULL;
if(Head1==NULL)
return Head2;
if(Head2==NULL)
return Head1;
if(Head1==NULL&&Head2==NULL)
return NULL;
if(Head1->m_nValue>Head2->m_nValue)
{
MergeHead=Head2;
Head2->m_pNext=MergeLink(Head2->m_pNext,Head1);
}
else
{
MergeHead=Head1;
Head1->m_pNext=MergeLink(Head1->m_pNext,Head2);
}
return MergeHead;
}
void main()
{
int a[]={,,,,};
int b[]={,,};
ListNode* Head1=CreateList(a,);
ListNode* Head2=CreateList(b,);
PrintList(Head1);
PrintList(Head2);
ListNode* Head3=MergeLink(Head1,Head2);
PrintList(Head3); }
Java代码:
public class MergeLink { public static class ListNode
{
int m_nValue;
ListNode m_pNext;
};
public static ListNode CreateList(int[] a,int b)
{ ListNode pHead=null,pNode=null;
for(int i=0;i<b;i++)
{
ListNode pNew=new ListNode();
pNew.m_nValue=a[i];
pNew.m_pNext=null;
if(pHead==null)
{
pHead=pNew;
pNode=pNew; }
else
{
pNode.m_pNext=pNew;
pNode=pNode.m_pNext;
}
}
return pHead;
}
public static void PrintList(ListNode pHead)
{
if(pHead==null)
{
return;
}
ListNode pNode=pHead;
while(pNode!=null)
{ System.out.print(pNode.m_nValue+" ");
pNode=pNode.m_pNext; }
System.out.println();
}
public static ListNode MergeLink(ListNode Head1,ListNode Head2)
{
ListNode MergeHead=null;
if(Head1==null)
return Head2;
if(Head2==null)
return Head1;
if(Head1==null&&Head2==null)
return null;
if(Head1.m_nValue>Head2.m_nValue)
{
MergeHead=Head2;
Head2.m_pNext=MergeLink(Head2.m_pNext,Head1);
}
else
{
MergeHead=Head1;
Head1.m_pNext=MergeLink(Head1.m_pNext,Head2);
}
return MergeHead;
}
public static void main(String[] args)
{
int a[]={3,4,5,6,8};
int b[]={1,2,7};
ListNode Head1=CreateList(a,5);
ListNode Head2=CreateList(b,3);
PrintList(Head1);
PrintList(Head2);
ListNode Head3=MergeLink(Head1,Head2);
PrintList(Head3); } }
剑指offer—第三章高质量代码(合并两个排序链表)的更多相关文章
- 剑指offer—第三章高质量代码(数值的整数次方)
高质量的代码:容错处理能力,规范性,完整性.尽量展示代码的可扩展型和可维护性. 容错处理能力:特别的输入和处理,异常,资源回收. 规范性:清晰的书写,清晰的布局,合理的命名. 完整性:功能测试,边界测 ...
- 剑指offer—第三章高质量代码(o(1)时间删除链表节点)
题目:给定单向链表的头指针和一个节点指针,定义一个函数在O(1)时间删除该节点,链表节点与函数的定义如下:struct ListNode{int m_nValue;ListNode* m_pValue ...
- 剑指offer—第三章高质量的代码(按顺序打印从1到n位十进制数)
题目:输入一个数字n,按照顺序打印出1到最大n位十进制数,比如输入3,则打印出1,2,3直到最大的3位数999为止. 本题陷阱:没有考虑到大数的问题. 本题解题思路:将要打印的数字,看成字符串,不足位 ...
- 剑指offer——python【第16题】合并两个有序链表
题目描述 将两个有序链表合并为一个新的有序链表并返回.新链表是通过拼接给定的两个链表的所有节点组成的. 示例: 输入:1->2->4, 1->3->4 输出:1->1-& ...
- 《剑指offer》第二十五题(合并两个排序的链表)
// 面试题25:合并两个排序的链表 // 题目:输入两个递增排序的链表,合并这两个链表并使新链表中的结点仍然是按 // 照递增排序的.例如输入图3.11中的链表1和链表2,则合并之后的升序链表如链 ...
- 剑指offer第三章
剑指offer第三章 1.数值的整数次方 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. class Solution { public ...
- 剑指offer-第三章高质量代码(反转链表)
题目:定义一个函数,输入一个链表的头节点,反转该链表并输出反转链表的头节点. 思路:对一个链表反转需要三个指针操作来保证链表在反转的过程中保证不断链,给链表一个行动指针pNode,对pNode指向的节 ...
- 剑指offer-第三章高质量代码(树的子结构)
题目:输入两个二叉树A和B,判断B是不是A的子结构. 思路:遍历A树找到B树的根节点,然后再判断左右子树是否相同.不相同再往下找.重复改过程. 子结构的描述如下图所示: C++代码: #include ...
- 剑指offer第五章
剑指offer第五章 1.数组中出现次数超过一半的数 数组中有一个数字出现的次数超过数组长度的一半,请找出这个数字. 例如输入一个长度为9的数组{1,2,3,2,2,2,5,4,2}.由于数字2在数组 ...
随机推荐
- Mybatis之基础应用小结以及IntelliJ IDEA目录结构的一些小问题
IntelliJ IDEA 目录结构的一些小问题 [Mybatis 之基础应用小结] 1.不管怎么样,先建立一个简单的MySQL数据表,如下所示 2.接下来要做的事情就是通过Mybatis对数据表进行 ...
- Zabiix 监控图形乱码问题
Zabiix切换为中文 配置中文乱码问题 在C:\Windows\Fonts中复制想要的字体,后缀为ttf,若本身问大写,请改成小写的文件后缀ttf,并上传至zabbix服务器的/usr/local/ ...
- 《网络对抗》 逆向及Bof进阶实践
<网络对抗> 逆向及Bof进阶实践 实践目标 注入一个自己制作的shellcode并运行这段shellcode: 实践步骤 准备工作 root@5224:~# apt-get instal ...
- APPIUM API整理(python)---元素查找
最近在学习自动化框架appium,网上找一些API相关资料整理了一下 1.find_element_by_id find_element_by_id(self, id_): Finds element ...
- Linux下解压分包文件zip(zip/z01/z02)【转】
本文转载自:https://www.cnblogs.com/EasonJim/p/7227109.html?utm_source=itdadao&utm_medium=referral Lin ...
- 《Maven实战》第10章 使用Maven进行测试
10.2maven-surefire-plugin插件 [生命周期]的[阶段]与[插件]的[目标]绑定 default生命周期的test阶段:使用单元测试框架运行测试 Maven内置绑定:defaul ...
- [BZOJ2017][Usaco2009 Nov]硬币游戏
Description 农夫约翰的奶牛喜欢玩硬币游戏,因此他发明了一种称为“Xoinc”的两人硬币游戏. 初始时,一个有N(5 <= N <= 2,000)枚硬币的堆栈放在地上,从堆顶数起 ...
- 初入spring boot(五 )websocket
一.广播式 广播式即服务端有消息时,会将消息发送给所有连接了当前endpoint的浏览器 1.配置websocket,需要在配置类上使用@EnableWebSocketMessageBroker开启w ...
- 分布式技术 webapi
webapi可以返回json.xml类型的数据,对于数据的增.删.改.成,提供对应的资源操作,按照请求的类型进行相应的处理,主要包括 Get(查).Post(增).Put(改).Delete(删),这 ...
- Java数据类型——面试题
1.short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 +=1;有什么错? 答:对于short s1=1;s1=s1+1来说,在s1+1运算时会自动提升表 ...