标题:单链表操作 无错误但运行遇到停止工作,求助!!
只看楼主
zhuhong1990
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2012-11-28
结帖率:0
已结贴  问题点数:20 回复次数:3 
单链表操作 无错误但运行遇到停止工作,求助!!
#include<stdio.h>
#include<malloc.h>
#include<conio.h>
typedef struct
{
    int xs;//系数;
    int zs;//指数;
}
ElemType;
typedef struct LNode
{
    ElemType data;
    struct LNode *next;
}
LNode,*LinkList;
LinkList initList()   //创建链表
{
    LinkList L;
    L=(LinkList)malloc(sizeof(LNode));
    L->next=NULL;
    return(L);
}
void InsLNode(LinkList L,ElemType x)//插入链表
{
    LinkList p1,p2;
    p1=(LinkList)malloc(sizeof(LNode));
    p1->data=x;
    p2=L;
    while(p2->next)
        p2=p1->next;
        p1->next=NULL;
        p2->next=p1;
}
void AddPolyn(LinkList pa,LinkList pb)
{
    LinkList a1,b1,a2,b2;
   int sum;
    int a,b;
    a1=pa;
    b1=pb;
    a2=a1->next;
    b2=b1->next;
    while(a2&&b2)
    {
        a=a2->data.zs;
        b=b2->data.zs;
        if(a<b)
        {
            a1=a2;
            a2=a2->next;
        }
        if(a==b)
        {
            sum=a2->data.xs+b2->data.xs;
            if(sum!=0)
            {
                a2->data.xs=sum;
            }
            else
            {
                a1->next=a2->next;
                free(a2);
                a2=a1->next;
                b1->next=b2->next;
                free(b2);
                b2=b1->next;
            }
            }
        if(a>b)
        {
            b1->next=b2->next;
            b2->next=a1->next;
            a1->next=b2;
            a1=b2;
            free(b2);
            b2=b1->next;
        }
    }
        if(b2)
            a1->next=b2;
        free(b1);
   
}
void Invert(LinkList L)//逆序输入链表
{
    LinkList p,q,r;
    p=L->next;
    q=p->next;
    while(q!=NULL)
    {
        r=q->next;
        q->next=p;
        p=q;
        p=r;
    }
    L->next->next=NULL;
    L->next=p;
}
void print(LinkList L)//输出多项式
{
    LinkList p;
    p=L->next;
    while(p->next)
    {
        printf("%ix^%d+",p->data.xs,p->data.zs);
        p=p->next;
    }
    printf("%ix^%d",p->data.xs,p->data.zs);
}
void main()
{
    LinkList La,Lb;
    ElemType c;
    int a,i;
    La=initList();
    Lb=initList();
    printf("\n");
    printf("输入La的项数:");
    scanf("%d",&a);
    for(i=0;i<a;i++)
    {
        printf("输入La的第%d项系数:",i+1);
        scanf("%i",&c.xs);
        printf("输入La的第%d项指数:",i+1);
        scanf("%d",&c.zs);
        InsLNode(La,c);
    }
    printf("输入Lb的项数:");
    scanf("%d",&a);
    for(i=0;i<a;i++)
    {
        printf("输入Lb的第%d项系数:",i+1);
        scanf("%i",&c.xs);
        printf("输入Lb的第%d项指数:",i+1);
        scanf("%d",&c.zs);
        InsLNode(Lb,c);
    }
    printf("多项式和为:");
    printf("\n");
    AddPolyn(La,Lb);
    Invert(La);
    print(La);
}



运行成功但是输入到第四行数字之后回车就弹出停止工作,怎么处理???还是代码里有错误?

[ 本帖最后由 zhuhong1990 于 2012-11-28 17:34 编辑 ]
搜索更多相关主题的帖子: include 工作 next return 
2012-11-28 17:33
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6809
专家分:42393
注 册:2010-12-16
得分:10 
void InsLNode(LinkList L,ElemType x)//插入链表
 {
     LinkList p1,p2;
     p1=(LinkList)malloc(sizeof(LNode));
     p1->data=x;
     p2=L;
     while(p2->next)
         p2=p2->next; //  p2=p1->next;
         
     p1->next=NULL;
     p2->next=p1;
 }
程序崩溃时这个地方的错误导致的

不过你的程序有死循环,自己跟踪下吧,

我行我乐
我的博客:
http://blog.yuccn. net
2012-11-28 22:57
凌云飞翔
Rank: 5Rank: 5
来 自:河北
等 级:职业侠客
威 望:6
帖 子:98
专家分:388
注 册:2012-4-7
得分:10 
程序代码:
#include<stdio.h>
#include<malloc.h>
#include<conio.h>
typedef struct
{
    int xs;//系数;
    int zs;//指数;
}
ElemType;
typedef struct LNode
{
    ElemType data;
    struct LNode *next;
}
LNode,*LinkList;
LinkList initList()   //创建链表
{
    LinkList L;
    L=(LinkList)malloc(sizeof(LNode));
    L->next=NULL;
    return(L);
}
void InsLNode(LinkList &L,ElemType x)//插入链表
{
    LinkList p1,p2;
    p1=(LinkList)malloc(sizeof(LNode));
    p1->data=x;
    p2=L;
    while(p2->next)
        p2=p2->next;
        p1->next=NULL;
        p2->next=p1;
}
void AddPolyn(LinkList &pa,LinkList &pb)
{
    LinkList a1,b1,a2,b2;
    int sum;
    int a,b;
    a1=pa;
    b1=pb;
    a2=a1->next;
    b2=b1->next;
    while(a2&&b2)
    {
        a=a2->data.zs;
        b=b2->data.zs;
        if(a<b)
        {
            a1=a2;
            a2=a2->next;
        }
        if(a==b)
        {
            sum=a2->data.xs+b2->data.xs;
            if(sum!=0)
            {
                a2->data.xs=sum;
                a1=a2 ;
                a2=a2->next;
              b1->next=b2->next ;
                free (b2) ;
                b2=b1->next;
            }

            else
            {
                a1->next=a2->next;
                free(a2);
                a2=a1->next;
                b1->next=b2->next;
                free(b2);
                b2=b1->next;
            }
            }
        if(a>b)
        {
            b1->next=b2->next;
            b2->next=a2;
            a1->next=b2;
            a1=b2;
           b2=b1->next;
        }
    }
        if(b2)
            a1->next=b2;
        free(b1);
   
}

void print(LinkList L)//输出多项式
{
    LinkList p;
    p=L->next;
    while( p )
    {
        printf("%ix^%d+",p->data.xs,p->data.zs);
        p=p->next;
        if (p->next==0)
        {  printf("%ix^%d",p->data.xs,p->data.zs);
                   break  ;
        }
    }
  
}

 main()
{
    LinkList La,Lb;
    ElemType c;
    int a,i;
    La=initList();
    Lb=initList();
    printf("\n");
    printf("输入La的项数:");
    scanf("%d",&a);
    for(i=0;i<a;i++)
    {
        printf("输入La的第%d项系数:",i+1);
        scanf("%i",&c.xs);
        printf("输入La的第%d项指数:",i+1);
        scanf("%d",&c.zs);
        InsLNode(La,c);
    }
    printf("输入Lb的项数:");
    scanf("%d",&a);
    for(i=0;i<a;i++)
    {
        printf("输入Lb的第%d项系数:",i+1);
        scanf("%i",&c.xs);
        printf("输入Lb的第%d项指数:",i+1);
        scanf("%d",&c.zs);
        InsLNode(Lb,c);
    }
    printf("多项式和为:\n");

 
    AddPolyn(La,Lb);
    print(La);
   printf("\n");
}
2012-12-01 01:35
凌云飞翔
Rank: 5Rank: 5
来 自:河北
等 级:职业侠客
威 望:6
帖 子:98
专家分:388
注 册:2012-4-7
得分:0 
2012-12-01 01:36



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-388863-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.103365 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved