7-9 两个有序链表序列的合并
已知两个非降序链表序列S1与S2,设计函数构造出S1与S2合并后的新的非降序链表S3。
输入格式
输入分两行,分别在每行给出由若干个正整数构成的非降序序列,用−1表示序列的结尾(−1不属于这个序列)。数字用空格间隔。
输出格式:
在一行中输出合并后新的非降序链表,数字间用空格分开,结尾不能有多余空格;若新链表为空,输出NULL。
输入样例:
下面展示一些 内联代码片
。
1 3 5 -1
2 4 6 8 10 -1
输出样例:
1 2 3 4 5 6 8 10
代码如下:
#include<stdio.h>
#include<malloc.h>
typedef struct LNode{
int data;
struct LNode* next;
}LNode,*LinkList;
LinkList Creat_List();
void Travel(LinkList H);
LinkList Combine_List(LinkList A,LinkList B);
int main(){
struct Node* A,*B,*C;
A = Creat_List();
B = Creat_List();
C = Combine_List(A,B);
Travel(C);
return 0;
}
void Travel(struct Node* H){
if(H->next){
struct Node* p;
p=H->next;
while(p){
printf("%d",p->data);
if(p->next != NULL) printf(" ");
p = p->next;
}
printf("\n");
}
else printf("NULL");
}
struct Node* Creat_List(){
//尾插法
struct Node* H,*p,*q;
int x;
H = (struct Node*)malloc(sizeof(struct Node));
H->next = NULL;
q = H;
while(scanf("%d",&x) && x!=-1){
struct Node* p;
p = (struct Node*)malloc(sizeof(struct Node));
p->next=NULL;
p->data = x;
q->next = p;
q = p;
}
return H;
}
struct Node* Combine_List(struct Node* A,struct Node* B){
//归并排序
struct Node* C,*p;
C= (struct Node*)malloc(sizeof(struct Node));
C->next = NULL;
p = C;
A = A->next;
B = B->next;
while(A&&B){
if(A->data > B->data){
p->next = B;
B = B->next;
p = p->next;
}
else{
p->next = A;
A = A->next;
p = p->next;
}
}
if(A){
p->next = A;
}
if(B){
p->next = B;
}
return C;
}