标题:谁能帮我解决一下这个 多项式相加 的 相加函数 解释一下 不知道怎么改
只看楼主
fan19980613
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2016-11-12
结帖率:0
已结贴  问题点数:5 回复次数:8 
谁能帮我解决一下这个 多项式相加 的 相加函数 解释一下 不知道怎么改
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
typedef int mytype;
typedef struct Node
{
    mytype xi;
    mytype zhi;
    Node *next;
}PNode,*PList;
void initPList(PList &L,int n)
{
    L=(PList)malloc(sizeof(PNode));
    L->next=NULL;
    PList p=L;
    for(int i=0;i<n;i++)
    {
        PList s=(PList)malloc(sizeof(PNode));
        s->xi=rand()%23-30;
        s->zhi=i;
        p->next=s;
        s->next=NULL;
        p=s;
    }
}
void printPList(PList L)
{
    PList p=L->next;
    while(p)
    {
        printf("%dx%d",p->xi,p->zhi);
        p=p->next;
    }
    printf("\n");
}
void addPList(PList LA,PList LB)
{
    PList p=LA->next;
    PList q=LB->next;
    PList s=LB;
    while(p&&q)
    {
        if(p->zhi<q->zhi)
        {
            s->next=p;
            s=p;
            p=p->next;
        }
        if(p->zhi>q->zhi)
        {
            s->next=q;
            s=q;
            q=q->next;
        }
        if(p->zhi=q->zhi)
        {
            mytype sum;
            sum=p->xi+q->xi;
            if(sum!=0)
            {
                q->xi=sum;
                s=q;
                s->next=q;
                q=q->next;
                p=p->next;
            }
            else
            {
                q=q->next;
                p=p->next;
            }
        }
    }
    s->next=p?p:q;
}
int main()
{
    PList PLA,PLB;
    initPList(PLA,6);
    initPList(PLB,8);
    printPList(PLA);
    printPList(PLB);
    addPList(PLA,PLB);
    printPList(PLB);
}
搜索更多相关主题的帖子: 多项式 相加 int next sum 
2017-11-01 17:44
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
得分:2 
if(p->zhi=q->zhi)

if (p->zhi==q->zhi)

就看到了这个~不知道还有没有其它细节~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-11-01 19:00
fan19980613
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2016-11-12
得分:0 
回复 2楼 九转星河
改了那里  还是不能输出两个多项式 相加后的结果
2017-11-01 22:27
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
得分:0 
回复 3楼 fan19980613
这个我需要时间~然而最近我还有别的事……还是看看有没有其他人来看看吧~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-11-01 23:18
炎天
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:桃花岛
等 级:贵宾
威 望:29
帖 子:1218
专家分:4986
注 册:2016-9-15
得分:2 
以下是引用九转星河在2017-11-1 23:18:17的发言:

这个我需要时间~然而最近我还有别的事……还是看看有没有其他人来看看吧~

不知道九转大佬最近在忙什么呢?

早知做人那么辛苦!  当初不应该下凡
2017-11-02 10:27
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
得分:0 
回复 5楼 炎天
萌进入呆萌囧的代码状态……还是等我有成果在
再说吧~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2017-11-02 18:06
fan19980613
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2016-11-12
得分:0 
还有没有大佬帮忙指出一下问题
2017-11-03 00:06
zbjzbj
Rank: 12Rank: 12Rank: 12
来 自:郑州
等 级:贵宾
威 望:52
帖 子:620
专家分:3020
注 册:2011-4-22
得分:2 
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
typedef int mytype;
typedef struct Node
{
    mytype xi;
    mytype zhi;
    Node *next;
}PNode,*PList;
void initPList(PList &L,int n)
{
    L=(PList)malloc(sizeof(PNode));
    L->next=NULL;
    PList p=L;
    for(int i=0;i<n;i++)
    {
        PList s=(PList)malloc(sizeof(PNode));
        s->xi=rand()%23-30;
        s->zhi=i;
        p->next=s;
        s->next=NULL;
        p=s;
    }
}
void printPList(PList L)
{
    PList p=L->next;
    while(p)
    {
        printf("%dx%d",p->xi,p->zhi);
        p=p->next;
    }
    printf("\n");
}
void addPList(PList LA,PList LB)
{
    PList p=LA->next;
    PList q=LB->next;
    PList s=LB;
    while(p&&q)
    {
        if(p->zhi<q->zhi)
        {
            s->next=p;
            s=p;
            p=p->next;
        }
        if(p->zhi>q->zhi)
        {
            s->next=q;
            s=q;
            q=q->next;
        }
        if(p->zhi==q->zhi)
        {
            mytype sum;
            sum=p->xi+q->xi;
            if(sum!=0)
            {
                q->xi=sum;
                s=q;
                s->next=q->next;
                q=q->next;
                p=p->next;
            }
            else
            {
                q=q->next;
                p=p->next;
            }
        }
    }
    s->next=p?p:q;
}
int main()
{
    PList PLA,PLB;
    initPList(PLA,6);
    initPList(PLB,8);
    printPList(PLA);
    printPList(PLB);
    addPList(PLA,PLB);
    printPList(PLB);
}
2017-11-03 00:42
fan19980613
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2016-11-12
得分:0 
回复 8楼 zbjzbj
谢谢,看了你的之后  明白了 问题所在



2017-11-03 17:00



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




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

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