#include<stdio.h>
#include<stdlib.h>
#define MAXSIZE 20;
typedef struct LNode{
int data;
struct LNode *next;
} LNode,*LinkList;
LinkList mergelinklist(LinkList La,LinkList Lb);
int main(){
LinkList La,Lb;
int n,m;
La=(LinkList)malloc(sizeof(LNode));
La->next=NULL;
Lb=(LinkList)malloc(sizeof(LNode));
Lb->next=NULL;
scanf("%d %d",&n,&m);
LinkList last=La;
for(int i=0;i<n;i++)
{
LinkList p;
p=(LinkList)malloc(sizeof(LNode));
scanf("%d",&p->data);
p->next=NULL;
last->next=p;
last=last->next;
}
last=Lb;
for(int i=0;i<m;i++)
{
LinkList p;
p=(LinkList)malloc(sizeof(LNode));
scanf("%d",&p->data);
p->next=NULL;
last->next=p;
last=last->next;
}
La=mergelinklist(La,Lb);
LinkList p=La;
p=p->next;
while(p){
printf("%d ",p->data);
p=p->next;
}
return 0;
}
LinkList mergelinklist(LinkList La,LinkList Lb){
LinkList pa,pb;
pa=La->next;
pb=Lb->next;
La->next=NULL;
while(pa&&pb){
if(pa->data<=pb->data){
LinkList p=pa->next;
pa->next=La->next;
La->next=pa;
pa=p;
}
else{
LinkList p=pb->next;
pb->next=La->next;
La->next=pb;
pb=p;
}
}
LinkList q=pa?pa:pb;
while(q){
LinkList p=q->next;
q->next=La->next;
La->next=q;
q=p;
}
return La;
}
算法代码
LinkList mergelinklist(LinkList La,LinkList Lb){
//将两个非递减链表合并为一个非递增有序链表,只用La,Lb已有的存储空间。
LinkList pa,pb;
pa=La->next; //pa,pb用来存储La,Lb的首元结点的地址
pb=Lb->next;
free(Lb); //释放Lb的头结点
La->next=NULL; //令La做新链表的头结点,头结点的next初始化为NULL。
while(pa&&pb){
if(pa->data<=pb->data){
LinkList p=pa->next; //存储pa的下一个结点的地址
pa->next=La->next; //利用头插法连接到新链表La
La->next=pa;
pa=p; //pax向下移一位
}
else{ //与上面类似
LinkList p=pb->next;
pb->next=La->next;
La->next=pb;
pb=p;
}
}
LinkList q=pa?pa:pb; //pa,pb哪一个没到尾就赋值给q
while(q){
LinkList p=q->next; //对q遍历,用尾插法插入到La。
q->next=La->next;
La->next=q;
q=p;
}
return La;
}