这个链表合并的问题在于若a 链表为
1,98
10,98
b链表为
2,98
3,98
只能将b链表的第一个数插入a链表
struct student
{
long num;
int score;
struct student * next;
};
struct student *insert(struct student *ah,struct student *bh)
{
struct student *pa1,*pb1,*pa2,*pb2;
pa1=pa2=ah;
pb1=pb2=bh;
do
{
while(pb1->num>pa1->num&&pa1->next!=NULL)
{
pa2=pa1;
pa1=pa1->next;
}
if(pb1->num<pa1->num)
{
if(ah==pa1)
ah=pb1;
else
pa2->next=pb1;
pb1=pb1->next;
pb2->next=pa1;
pa2=pb2;
pb2=pb1;
}
}while((pa1->next!=NULL)&&(pb1!=NULL));
if((pb1!=NULL)&&(pb1->num>pa1->num)&&(pa1->next==NULL))
pa1->next=pb1;
return ah;
}
}while((pa1->next!=NULL)&&(pb1!=NULL));
pa1->next!=NULL应改为pa1 != NULL
因为前面已经有pa1=pa1->next;了,pa1指向下一个要比较的结点,不应该再next了
另外提个建议,你的变量名可以取得更有意义一些,例如pa1是用来指向下一个结点的指针,就叫paNext,pa2用来指向当前正在比较的结点,就叫paCur,pb1、pb2也是同理。这样不仅别人看起来清楚,自己以后再看的时候也清楚
你可以看下,我博客中的单链表操作,希望可以帮到你