题目要求
已知两个非降序链表序列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
代码如下
- 第一次代码
一个数据点超时。未注意题目中S1、S2也是非降序,而采用了头插法创建链表,并且将合并与排序分开进行。这可能就是超时的原因。
#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);
void Lsort(LinkList &H);
int main(){
LinkList A,B,C;
A = Creat_List();
B = Creat_List();
C = Combine_List(A,B);
Lsort(C);
Travel(C);
return 0;
}
void Travel(LinkList H){
if(H->next){
LinkList p;
p=H->next;
while(p){
printf("%d",p->data);
if(p->next != NULL) printf(" ");
p = p->next;
}
printf("\n");
}
else printf("NULL");
}
LinkList Creat_List(){
//头插法
LinkList H,p;
int x;
H = (LNode*)malloc(sizeof(LNode));
H->next = NULL;
while(scanf("%d",&x) && x!=-1){
LinkList p;
p = (LNode*)malloc(sizeof(LNode));
p->data = x;
p->next = H->next;
H->next = p;
}
return H;
}
LinkList Combine_List(LinkList A,LinkList B){
LinkList p=A;
while(p->next) p=p->next;
p->next = B->next;
return A;
}
void Lsort(LinkList &H){
LinkList p,q;
if(H->next==NULL) ;
else if(H->next->next==NULL) ;
else{
for(p = H->next; (p->next)!=NULL; p=p->next){
for(q = p->next; q!=NULL; q=q->next){
if(q->data<p->data){
int t;
t= q->data;
q->data = p->data;
p->data = t;
}
}
}
}
}
- 第二次代码
使用尾插法创建链表,并且使用归并排序函数,完成合并与排序。
#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(){
LinkList A,B,C;
A = Creat_List();
B = Creat_List();
C = Combine_List(A,B);
Travel(C);
return 0;
}
void Travel(LinkList H){
if(H->next){
LinkList p;
p=H->next;
while(p){
printf("%d",p->data);
if(p->next != NULL) printf(" ");
p = p->next;
}
printf("\n");
}
else printf("NULL");
}
LinkList Creat_List(){
//尾插法
LinkList H,p,q;
int x;
H = (LNode*)malloc(sizeof(LNode));
H->next = NULL;
q = H;
while(scanf("%d",&x) && x!=-1){
LinkList p;
p = (LNode*)malloc(sizeof(LNode));
p->next=NULL;
p->data = x;
q->next = p;
q = p;
}
return H;
}
LinkList Combine_List(LinkList A,LinkList B){
//归并排序
LinkList C,p;
C= (LNode*)malloc(sizeof(LNode));
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;
}