合并两个线性表c 语言,如何用c程序建立两个线性表并把他们合并成一个线性表?...

满意答案

dcebd7a0de6265b6ccae5ead692f1eab.png

ryan_gan

推荐于 2017.11.23

dcebd7a0de6265b6ccae5ead692f1eab.png

采纳率:52%    等级:12

已帮助:14275人

从键盘输入两个链表,通过程序对他们排序,之后按递增顺序合并链表

#include "stdio.h"

#include "stdlib.h"

#include "malloc.h"

#define NULL 0

struct List

{

int data;

struct List *next;

}List;

struct List * InitList()

{

struct List *head,*p,*q;

int d;

head=(struct List *)malloc(sizeof(struct List));

head->next=NULL;

p=head;

scanf("%d",&d);

while(d>0)

{

q=(struct List *)malloc(sizeof(struct List));

q->next=NULL;

q->data=d;

p->next=q;

p=p->next;

scanf("%d",&d);

}

return head;

}

void ListChooseSort(struct List *head)

{

struct List *p,*q;

int t;

if(head->next!=NULL)

{

for(p=head->next;p->next;p=p->next)

for(q=p->next;q;q=q->next)

if(q->datadata)

{

t=p->data;

p->data=q->data;

q->data=t;

}

}

}

struct List * UniteList(struct List *a,struct List *b)

{

struct List *U_head,*p,*q,*s;

U_head=(struct List *)malloc(sizeof(struct List));

U_head->next=NULL;

p=a->next;

q=b->next;

s=U_head;

while(p&&q)

{

if(p->data>q->data)

{

s->next=q;

q=q->next;

}

else

{

s->next=p;

p=p->next;

}

s=s->next;

}

if(p==NULL)s->next=q;

else s->next=p;

return U_head;

}

void ListPrint(struct List *head)

{

struct List *p;

p=head->next;

printf("\n\n");

while(p)

{

printf("%5d",p->data);

p=p->next;

}

printf("\n\n");

}

void main ()

{

struct List *a_head,*b_head,*Unite_head;

printf("\n创建链表a:\n\n");

a_head=InitList();

printf("\n链表a:");

ListPrint(a_head);

system("pause");

system("cls");

printf("\n创建链表b:\n\n");

b_head=InitList();

printf("\n链表b:");

ListPrint(b_head);

system("pause");

system("cls");

ListChooseSort(a_head);

printf("\n递增排序后的链表a:");

ListPrint(a_head);

ListChooseSort(b_head);

printf("递增排序后的链表b:");

ListPrint(b_head);

Unite_head=UniteList(a_head,b_head);

printf("合并后的链表为:");

ListPrint(Unite_head);

}

00分享举报

  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值