C语言中数据结构之链表归并排序实例代码
2019/7/10 22:46:58
本文主要是介绍C语言中数据结构之链表归并排序实例代码,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
C语言中数据结构之链表归并排序实例代码
问题
设有两个无头结点的单链表,头指针分别为ha,hb,链中有数据域data,链域next,两链表的数据都按递增排序存放,现要求将hb表归到ha表中,且归并后ha仍递增序,归并中ha表中已有的数据若hb中也有,则hb中的数据不归并到ha中,hb的链表在算法中不允许破坏。
源程序
#include <stdio.h> #include<stdlib.h> #define N1 6 /*链表La的长度*/ #define N2 6 /*链表Lb的长度*/ struct listnode { int data; struct listnode *next; }; void createlist(struct listnode * *,int); void listinsert(struct listnode * *,struct listnode * *); void readlist(struct listnode *); int main() { struct listnode *ha=NULL,*hb=NULL; printf("请按照升序序列输入以下数字以建立链表La\n"); printf("Please Input %d numbers:",N1); createlist(&ha,N1); printf("请按照升序序列输入以下数字以建立链表Lb\n"); printf("Please Input %d numbers:",N2); createlist(&hb,N2); listinsert(&ha,&hb); readlist(ha); printf("\n"); } void createlist(struct listnode * *p,int n) { /*尾插法建立链表*/ struct listnode *t,*q; int i; t=(struct listnode *)malloc(sizeof(struct listnode)); scanf("%d",&t->data); *p=t; q=t; for(i=n-1;i>0;i--) { t=(struct listnode *)malloc(sizeof(struct listnode)); scanf("%d",&t->data); q->next=t; q=t; } q->next=NULL; } void listinsert(struct listnode * *a,struct listnode * *b) { /*将两个链表按递增序列排序*/ struct listnode *pa,*pb,*other,*la,*pre; la=(struct listnode *)malloc(sizeof(struct listnode)); la->next=*a; pa=*a; pb=*b; pre=la; while(pa&&pb) { if(pa->data<pb->data) { pre=pre->next; pa=pa->next; } else if (pa->data>pb->data) { other=(struct listnode *)malloc(sizeof(struct listnode)); other->data=pb->data; other->next=pa; pre->next=other; pre=other; pb=pb->next; } else { pre=pre->next; pa=pa->next; pb=pb->next; } } if(!pa) { while(pb) { other=(struct listnode *)malloc(sizeof(struct listnode)); other->data=pb->data; pre->next=other; pre=pre->next; pb=pb->next; } pre->next=NULL; } *a=la->next; free(la); } void readlist(struct listnode *p) { /*遍历链表并输出最终结果*/ struct listnode *q; q=p; printf("链表的排序结果为:\n"); while(q!=NULL) { printf("%3d",q->data); q=q->next; } printf("\n"); }
运行结果
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
这篇关于C语言中数据结构之链表归并排序实例代码的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23增量更新怎么做?-icode9专业技术文章分享
- 2024-11-23压缩包加密方案有哪些?-icode9专业技术文章分享
- 2024-11-23用shell怎么写一个开机时自动同步远程仓库的代码?-icode9专业技术文章分享
- 2024-11-23webman可以同步自己的仓库吗?-icode9专业技术文章分享
- 2024-11-23在 Webman 中怎么判断是否有某命令进程正在运行?-icode9专业技术文章分享
- 2024-11-23如何重置new Swiper?-icode9专业技术文章分享
- 2024-11-23oss直传有什么好处?-icode9专业技术文章分享
- 2024-11-23如何将oss直传封装成一个组件在其他页面调用时都可以使用?-icode9专业技术文章分享
- 2024-11-23怎么使用laravel 11在代码里获取路由列表?-icode9专业技术文章分享
- 2024-11-22怎么实现ansible playbook 备份代码中命名包含时间戳功能?-icode9专业技术文章分享