本文共 1793 字,大约阅读时间需要 5 分钟。
本题要求实现一个函数,将两个链表表示的递增整数序列合并为一个非递减的整数序列。
函数接口定义:
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;}/* 你的代码将被嵌在这里 */List Read(){ int n; scanf("%d",&n); List L=(struct Node *)malloc(sizeof(struct Node)); L->Next=NULL; List ans=L; while (n--){ if (L->Next==NULL){ List temp=(struct Node *)malloc(sizeof(struct Node)); temp->Next=NULL; scanf("%d",&temp->Data); L->Next=temp; L=L->Next; } } return ans;}void Print( List L ){ if (L->Next==NULL){ printf("NULL\n"); return; } List temp=L->Next; while (temp){ printf("%d ",temp->Data); temp=temp->Next; } printf("\n");}List Merge( List L1, List L2 ){ List L3=(struct Node *)malloc(sizeof(struct Node)); List L=L3; List p=L1->Next; List q=L2->Next; while (p && q){ if (p->Data < q->Data){ L->Next=p; p=p->Next; } else{ L->Next=q; q=q->Next; } L=L->Next; } L->Next=NULL; if (p) L->Next=p; if (q) L->Next=q; L1->Next=NULL; L2->Next=NULL; return L3;}
转载地址:http://xdbqb.baihongyu.com/