02 |
您所在的位置:网站首页 › 合并两个单链表使其呈递增序列 › 02 |
本题要求实现一个函数,将两个链表表示的递增整数序列合并为一个非递减的整数序列。 函数接口定义: 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 |