两个无序单链表 排序后合并成一个有序链表

分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow

也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!

               

两个无序单链表,排序后合并成一个有序链表

 

算法思想:用冒泡法,对链表1和2进行排序,对排序后的两个链表,从小到大进行循环,装入链表3中。

#include<stdio.h>#include<stdlib.h>struct stud/*定义链表*/{int data;struct stud *next;};void pai_xue(struct stud *head1,struct stud *head2,int count1,int count2)/*冒泡排序法*/{int i,j,temp=0;struct stud *p;for(i=0;i<count1-1;++i)   for(p=head1->next;p->next!=NULL;p=p->next)/*对链表1进行排序*/   {    if(p->data>p->next->data)    {    temp=p->data;    p->data=p->next->data;    p->next->data=temp;    }   }   for(i=0;i<count2-1;++i)   for(p=head2->next;p->next!=NULL;p=p->next)/*对链表2进行排序*/   {    if(p->data>p->next->data)    {    temp=p->data;    p->data=p->next->data;    p->next->data=temp;    }   }   printf("\n链表1排完序后\n");/*输出链表1和2*/   p=head1->next;   while(p)   {   printf("%d",p->data);   p=p->next;   }   printf("\n");   printf("\n链表2排完序后\n");   p=head2->next;   while(p)   {   printf("%d",p->data);    p=p->next;   }   printf("\n");  }void main(){struct stud *head1,*head2,*p,*q,*head3;int count1=1,count2=1;head3=(struct stud *)malloc(sizeof(struct stud *));/*定义链表头结点,并分配空间*/head3->next=NULL;head1=(struct stud *)malloc(sizeof(struct stud *));head2=(struct stud *)malloc(sizeof(struct stud *));p=(struct stud *)malloc(sizeof(struct stud *));q=(struct stud *)malloc(sizeof(struct stud *));head1->next=NULL;head2->next=NULL;printf("输入一个数据以999结束\n");scanf("%d",&p->data);while(p->data!=999)/*链表1输入数据*/{count1++;p->next=head1->next;head1->next=p;printf("输入一个数据以999结束\n");p=(struct stud *)malloc(sizeof(struct stud *));scanf("%d",&p->data);}printf("现在开始给第二个链表输入数据\n");printf("输入一个数据以999结束\n");scanf("%d",&q->data);while(q->data!=999)/*链表2输入数据*/{count2++;q->next=head2->next;head2->next=q;printf("输入一个数据以999结束\n");q=(struct stud *)malloc(sizeof(struct stud *));scanf("%d",&q->data);}pai_xue(head1,head2,count1,count2);head1=head1->next;head2=head2->next;while(head1!=NULL&&head2!=NULL)/*将排序好的链表1和2 的数据导入链表3*/{   if(head1->data<=head2->data)   {    p=head1->next;      head1->next=head3->next;    head3->next=head1;      head1=p;   }     else   {    q=head2->next;       head2->next=head3->next;    head3->next=head2;       head2=q;   }}if(head1!=NULL)/*如果有链表1或2的数据不为空,将剩下的数据导入链表3中*/{       p=head1;   while(p!=NULL)   {   q=p->next;   p->next=head3->next;   head3->next=p;   p=q;   }  }if(head2!=NULL){     q=head2;   while(q!=NULL)   {    p=q->next;    q->next=head3->next;    head3->next=q;    q=p;   }}q=head3->next;/*将链表倒置,原来是由大到小,倒置成由小到大*/head3->next=NULL;while(q!=NULL){   p=q->next;   q->next=head3->next;   head3->next=q;   q=p;}printf("两个链表合并后由小到大为\n");p=head3->next;while(p){printf("%d",p->data);p=p->next;}}

           

给我老师的人工智能教程打call!http://blog.csdn.net/jiangjunshow
这里写图片描述
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值