02

您所在的位置:网站首页 合并两个单链表使其呈递增序列 02

02

2024-07-10 08:04| 来源: 网络整理| 查看: 265

本题要求实现一个函数,将两个链表表示的递增整数序列合并为一个非递减的整数序列。

函数接口定义: List Merge( List L1, List L2 );

其中List结构定义如下:

typedef struct Node *PtrToNode; struct Node { ElementType Data; /* 存储结点数据 */ PtrToNode Next; /* 指向下一个结点的指针 */ }; typedef PtrToNode List; /* 定义单链表类型 */

L1和L2是给定的带头结点的单链表,其结点存储的数据是递增有序的;

函数Merge要将L1和L2合并为一个非递减的整数序列。

应直接使用原序列中的结点,返回归并后的带头结点的链表头指针。

裁判测试程序样例: #include #include typedef int ElementType; typedef struct Node *PtrToNode; struct Node { ElementType Data; PtrToNode Next; }; typedef PtrToNode List; List Read(); /* 细节在此不表 */ void Print( List L ); /* 细节在此不表;空链表将输出NULL */ List Merge( List L1, List L2 ); int main() { List L1, L2, L; L1 = Read(); L2 = Read(); L = Merge(L1, L2); Print(L); Print(L1); Print(L2); return 0; } /* 你的代码将被嵌在这里 */ 输入样例: 3 1 3 5 5 2 4 6 8 10 输出样例: 1 2 3 4 5 6 8 10 NULL NULL 思路 初始化一个新的单链表L,注意同时定义一个List类型的L0用来保存新链表的首地址,用于返回用两个指针分别指向两个链表中的第一个节点,比较-->链入-->指针下移,哪个大就把哪个链进L0,判断条件是两个指针都不等于NULL判断那个为空就把另一个之间链进L0,无需继续比较了要记得把原来的L1L2置空 备注 typedef struct Node *PtrToNode; struct Node {     ElementType Data; /* 存储结点数据 */     PtrToNode   Next; /* 指向下一个结点的指针 */ }; typedef PtrToNode List; /* 定义单链表类型 */    list也可以用来定义结构体变量,ptrtonode也可以。??                                                    L0 =(List)malloc(sizeof(PtrToNode));(类型是List,内容是PtrToNode??) List Merge( List L1, List L2 ){ List p,q,L0,L; L =(List)malloc(sizeof(PtrToNode)); L->Next=NULL; L0=L; p=L1->Next; q=L2->Next; while(p&&q){ //非递减-->递增,所以每次把小的链进去 if(p->Data>q->Data){ //q小把q所指链进去(让L指过来) //如何避免节点链进去以后原来的单链表没有指针了? //答:不能用插入节点的方法来链接节点,直接新链表指过去,然后指针后移 L->Next=q; q=q->Next; L=L->Next;//L用来标记下一个链入节点的前一个节点,L0不动用来标记新链链首 }else {//p小把p所指链进去(让L指过来) L->Next=p; p=p->Next; L=L->Next; } } //只要有一个链表空了,则另一个链表直接链进去(L指过来) if(p){ L->Next=p; }else{ L->Next=q; } L1->Next=NULL; L2->Next=NULL; //别忘了置空 return L0; }

 

 

 



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3