本文共 1342 字,大约阅读时间需要 4 分钟。
本题要求实现一个函数,将两个链表表示的递增整数序列合并为一个非递减的整数序列。
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;}/* 你的代码将被嵌在这里 */
31 3 552 4 6 8 10
1 2 3 4 5 6 8 10 NULLNULL
建一个新的头结点,然后建两个临时指针,然后比较大小,决定谁连着新的头结点所在的链表。。。
一定要注意临时节点的建立与使用。。。
代码如下:
List Merge( List L1, List L2 ){ if(L1==NULL&&L2==NULL) return NULL; List LL,t1=L1->Next,t2=L2->Next,t; LL=(List)malloc(sizeof(struct Node)); t=LL; t->Next=NULL; while (t1&&t2) { if(t1->DataData) { t->Next=t1; t1=t1->Next; } else { t->Next=t2; t2=t2->Next; } t=t->Next; } if (t1) t->Next=t1; if (t2) t->Next=t2; L2->Next=L1->Next=NULL; return LL;}
转载地址:http://ttaen.baihongyu.com/