标题:数据结构多项式相加,可以运行,但是输入数据后,不能显示结果
只看楼主
humeng
Rank: 1
等 级:新手上路
帖 子:18
专家分:4
注 册:2016-10-10
结帖率:40%
已结贴  问题点数:20 回复次数:5 
数据结构多项式相加,可以运行,但是输入数据后,不能显示结果
#include<stdio.h>
#include<stdlib.h>
typedef struct tt
{
    int a;
    int b;
    struct tt *next;
}LinkList;
LinkList *Int()
{
    LinkList *head,*s,*r;
    head=(LinkList*)malloc(sizeof(LinkList));
    r=head;
    int aa,bb;
    scanf("%d%d",&aa,&bb);
    while(aa)
    {
        s=(LinkList*)malloc(sizeof(LinkList));
        s->a=aa;
        s->b=bb;
        r->next=s;
        r=s;
        scanf("%d%d",&aa,&bb);
    }
    r->next=NULL;
    return head;
}
LinkList *Sum(LinkList *L,LinkList *H)
{
    LinkList *p,*q,*t,*k,*w;
    p=L->next;
    q=H->next;
    k=(LinkList*)malloc(sizeof(LinkList));
    w=k;
    while(p!=NULL&&q!=NULL)
    {
        if(p->b==q->b)
        {
            int sum;
            sum=p->a+q->a;
            if(sum==0)
            {
                t=p;
                p=p->next;
                free(t);
                t=q;
                q=q->next;
                free(t);
            }
            else
            {
                p->a=sum;
                k->next=p;
                k=k->next;
                p=p->next;
                t=q;
                q=q->next;
                free(t);
            }
        }
        if(p->b<q->b)
        {
            k->next=p;
            k=k->next;
            p=p->next;
        }
        if(p->b>q->b)
        {
            k->next=q;
            k=k->next;
            q=q->next;
        }
        if(p!=NULL)
          k->next=p;
        if(q!=NULL)
          k->next=q;
    }
    return w;
}
int main()
{
    LinkList *m,*n,*f,*p;
    m=Int();
    n=Int();
    f=Sum(m,n);
    p=f->next;
    int flag=0;
    while(p)
    {
        if(!flag)
            printf("%d*x^%d",p->a,p->b);
        else
        {
            if(p->a>0)
                printf("+%d*x^%d",p->a,p->b);
            else
                printf("%d*x^%d",p->a,p->b);
        }
        flag=1;
        p=p->next;
    }
    printf("\n");
    return 0;
}
搜索更多相关主题的帖子: return include 多项式 
2016-10-10 21:47
word123
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:13
帖 子:333
专家分:1622
注 册:2014-4-5
得分:20 
#include<stdio.h>
#include<stdlib.h>
typedef struct tt
{
    int a;
    int b;
    struct tt *next;
}LinkList;
LinkList *Int()
{
    LinkList *head,*s,*r;
    head=(LinkList*)malloc(sizeof(LinkList));
    r=head;
    int aa,bb;
    scanf("%d%d",&aa,&bb);
    while(aa)
    {
        s=(LinkList*)malloc(sizeof(LinkList));
        s->a=aa;
        s->b=bb;
        r->next=s;
        r=s;
        scanf("%d%d",&aa,&bb);
    }
    r->next=NULL;
    return head;
}
LinkList *Sum(LinkList *L,LinkList *H)
{
    LinkList *p,*q,*t,*k,*w;
    p=L->next;
    q=H->next;
    k=(LinkList*)malloc(sizeof(LinkList));
    w=k;
    while(p!=NULL&&q!=NULL)
    {
        if(p->b==q->b)
        {
            int sum;
            sum=p->a+q->a;
            if(sum==0)
            {
                t=p;
                p=p->next;
                free(t);
                t=q;
                q=q->next;
                free(t);
            }
            else
            {
                p->a=sum;
                k->next=p;
                k=k->next;
                p=p->next;
                t=q;
                q=q->next;
                free(t);
            }
        }else if(p->b<q->b)
        {
            k->next=p;
            k=k->next;
            p=p->next;
        }else if(p->b>q->b)
        {
            k->next=q;
            k=k->next;
            q=q->next;
        }
    }

    if(p!=NULL)
          k->next=p;
    else
          k->next=q;

    return w;
}
int main()
{
    LinkList *m,*n,*f,*p;
    m=Int();
    n=Int();
    f=Sum(m,n);
    p=f->next;
    int flag=0;
    while(p)
    {
        if(!flag)
            printf("%d*x^%d",p->a,p->b);
        else
        {
            if(p->a>0)
                printf("+%d*x^%d",p->a,p->b);
            else
                printf("%d*x^%d",p->a,p->b);
        }
        flag=1;
        p=p->next;
    }
    printf("\n");
    return 0;
}

//你的程序Sum函数有几个问题,主要就是三个判断没有使用条件分支,用if else if else if的结构
还有就是两个链表剩余的项应该在循环判断完之后再全部追加到新链表上
2016-10-10 22:33
humeng
Rank: 1
等 级:新手上路
帖 子:18
专家分:4
注 册:2016-10-10
得分:0 
回复 2楼 word123
先谢谢你,不过if语句可以不用加else对应啊,只是多用几个if而已,还有我最后在判断循环完后,有把剩余的链表加到新链表啊,问题不是这个吧,我把数据都输入后,按回车键,它不能显示结果,就是不能执行了,不知道怎么回事,你可以帮我改下代码,再发给我吗,谢谢,大神
2016-10-11 13:06
humeng
Rank: 1
等 级:新手上路
帖 子:18
专家分:4
注 册:2016-10-10
得分:0 
回复 2楼 word123
喔,我找到自己的问题了。。。谢谢
2016-10-11 13:14
word123
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:13
帖 子:333
专家分:1622
注 册:2014-4-5
得分:0 
你的本意是一次循环只比较两个数,而如果第一个if成立的话,指针会改变,到第二个if的话比较的两个数就不是之前的两个数了,还有或许p或q现在指向NULL了,再比较数据就会出错。。
用if
  else if
  else
的结构保证一次循环只比较两个数,也就是分支只有一个执行
while再判断是否为空。。再继续比较


还有你的
if(p!=NULL)
          k->next=p;
        if(q!=NULL)
          k->next=q;
这个语句是在循环体内,每次比较两个都把他加在k后面。。。
应该是比较完之后,退出while循环,再加入剩余的数据。。

你看一下是不是这样的。。。。
2016-10-11 13:15
humeng
Rank: 1
等 级:新手上路
帖 子:18
专家分:4
注 册:2016-10-10
得分:0 
回复 5楼 word123
恩,我知道啦,非常感谢大神
2016-10-11 21:04



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




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

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