从小到大依次输入两列整数,以-1表示结尾,然后根据这两列整数构造两个单向链表,按整数大大小关系把这两个链表合并成一个有序单向链表,最后从头到尾遍历输出这个链表的数据域(用一个空格隔开)。
1条回答
- threenewbee 2019-04-24 22:56关注
/*设head1和head2是两个非空单向链表,数据值有重复且升序排序 将head1和head2合并成一个升序链 */ #include<stdio.h> #include<stdlib.h> //定义结构体单元 typedef struct node{ int data;//结构体数据域 struct node* next;//结构体指针域 }ElemSN; //逆向创建单向链表(头插法) ElemSN *PreCreatLink(int a[],int n) { ElemSN *head=NULL,*p; for(int i=n-1;i>-1;i--) { p=(ElemSN*)malloc(sizeof(ElemSN)); p->data=a[i]; p->next=head; head=p; } return head; } ElemSN* Combine(ElemSN *head1,ElemSN *head2) { ElemSN *head,*p,*tail; head=NULL; while(head1&&head2) { if(head1->data<head2->data) { p=head1; head1=head1->next; } else { p=head2; head2=head2->next; } p->next=NULL; if(!head) head=tail=p; else { tail=tail->next=p; } } if(head1) p=head1; else p=head2; tail->next=p; return head; } //打印链表所有结点的值 void PrintLink(ElemSN* head) { ElemSN *p=head; for(;p;p=p->next) printf("%5d",p->data); } int main(void) { ElemSN *head1,*head2,*head; int a[7]={2,3,5,6,7,9,11}; int b[5]={2,4,5,7,9}; head1=PreCreatLink(a,7); //创建链表head1 head2=PreCreatLink(b,5); //创建链表head2 head=Combine(head1,head2); //将两个有序链表合并成一个有序链表 PrintLink(head); //输出链表 }
https://blog.csdn.net/vk5176891/article/details/53649225
https://blog.csdn.net/qq_39241239/article/details/80897992本回答被题主选为最佳回答 , 对您是否有帮助呢?解决评论 打赏 举报无用 3
悬赏问题
- ¥20 删除和修改功能无法调用
- ¥15 kafka topic 所有分副本数修改
- ¥15 小程序中fit格式等运动数据文件怎样实现可视化?(包含心率信息))
- ¥15 如何利用mmdetection3d中的get_flops.py文件计算fcos3d方法的flops?
- ¥40 串口调试助手打开串口后,keil5的代码就停止了
- ¥15 电脑最近经常蓝屏,求大家看看哪的问题
- ¥60 高价有偿求java辅导。工程量较大,价格你定,联系确定辅导后将采纳你的答案。希望能给出完整详细代码,并能解释回答我关于代码的疑问疑问,代码要求如下,联系我会发文档
- ¥50 C++五子棋AI程序编写
- ¥30 求安卓设备利用一个typeC接口,同时实现向pc一边投屏一边上传数据的解决方案。
- ¥15 SQL Server analysis services 服务安装失败