两个升序表合并成一个降序表.doc_第1页
两个升序表合并成一个降序表.doc_第2页
两个升序表合并成一个降序表.doc_第3页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

#include stdafx.h#include#includetypedef struct node char data; /data为结点的数据信息 struct node *next; /next为指向后继结点的指针LNode; /单链表结点类型LNode *CreateLinkList() /生成单链表 LNode *head,*p,*q; int i,n; head=(LNode*)malloc(sizeof(LNode); /生成头结点 head-next=NULL ; p=head; q=p; /指针q始终指向链尾结点 printf(输入链表的长度: n); scanf(%d, &n); /读入结点数据 printf(输入链表中元素的排列顺序为: n);for(i=n;i0;i-) /生成链表的数据结点 p=(LNode *)malloc(sizeof(LNode); /申请一个结点空间 scanf(%d,&p-data); p-next=NULL; q-next=p; /在链尾插入 q=p; return head; /返回指向单链表的头指针headvoid MergeList(LNode *A,LNode *B,LNode *C) /将升序链表A、B合并成降序链表*C LNode *p,*q,*s; p=A-next; / p指向链表A的第一个未比较的数据结点 q=B-next; / q指向链表B的第一个未比较的数据结点 *C=A; /生成链表的*C的头结点 (*C)-next=NULL; free(B); /释放链表B的头结点空间 while(p!=NULL&q!=NULL) /将A、B两链表中当前比较结点中值小的元素赋给*s if(p-datadata) s=p; p=p-next; else s=q; q=q-next; s-next=(*C)-next; /用头插法将结点*s插到链表*C的头结点之后 (*C)-next=s; if(p=NULL) /如果指向链表A的指针*p为空,则使*p指向链表B p=q; while(p!=NULL) /将*p所指链表中的剩余结点依次摘下插入的链表C的链首 s=p; p=p-next; s-next=(*C)-next; (*C)-next=s; void print(LNode *p) /输出单链表 p=p-next;while(p!=NULL)printf(%d,p-data);p=p-next;printf(n);int main(int argc, char* argv) LNode *A,*B,*C;printf(输入链表A:n);A=CreateLinkList(); /生成单链表Aprintf(输出链表A的元素为:n);print(A); /输出单链表Aprintf(输入链表B:n);B=CreateLinkList(); /生成单链表B printf(输出链表B的元素为:n);print(B); /输出单链表Bprintf(生成元素值递减的新链表C:n);MergeList(A,

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论