标题:一个菜鸟的白痴问题。单链表
只看楼主
Vi_No
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2009-5-15
结帖率:100%
 问题点数:0 回复次数:13 
一个菜鸟的白痴问题。单链表
各位同为菜鸟的同学好。数据结构的作业还是要自己做的。如果不会可以像本人一样求助。但是千万不要抄袭代码。因为抄袭不会帮助你提高。而且LZ的这段代码也是作业要交的。雷同就不好了。谢谢合作。
一元多项式相加。其实差不多就是单链表的合并。
编译通过。但是运行出错。
求高手解释。
#include <iostream>

using namespace std;

typedef struct LNode
{
    int CCs;
    int exp;
    struct LNode *next;
}LNode, *Multinomial;

void CreateMultinomial(Multinomial M)
{
    //创建链表
    M = (Multinomial)malloc(sizeof(LNode));
    M->next = NULL;
    Multinomial p;
    int i;
    cout << "请输入多项式的项数:\n";
    cin >> i;
    cout << "请依次输入多项式的系数和指数:\n";
    for (; i>0; i--)
    {
        p = (Multinomial)malloc(sizeof(LNode));
        cin >> p->CCs >> p->exp;
        p->next = M->next;
        M->next = p;
    }
}

void MergepMultinomial(Multinomial Ma, Multinomial Mb, Multinomial Mc)
{
    //合并多项式
    Multinomial pa = Ma->next,    //报错这个指令引用的内存不能为"read".
        pb = Mb->next, pc, tmpM;
        Mc = (Multinomial)malloc(sizeof(LNode));
        Mc->next = NULL;
    int tmp;
    while (pa && pb)
    {
        pc = (Multinomial)malloc(sizeof(LNode));
        if (pa->exp == pb->exp)
        {
            tmp = pa->CCs + pb->CCs;
            if (tmp)
            {
                pc->CCs = tmp;
                pc->exp = pa->exp;
                pc->next = Mc->next;
                Mc->next = pc;
                pa = pa->next;
                pb = pb->next;
            }
        }
        else if (pa->exp < pb->exp)
        {
            pc->CCs = pa->CCs;
            pc->exp = pa->exp;
            pc->next = Mc->next;
            Mc->next = pc;
            pa = pa->next;
        }
        else
        {
            pc->CCs = pb->CCs;
            pc->exp = pb->exp;
            pc->next = Mc->next;
            Mc->next = pc;
            pb = pb->next;
        }
    }
    pc = (Multinomial)malloc(sizeof(LNode));
    pc = tmpM = pa ? pa : pb;
    while (pc->next)
        pc = pc->next;
    pc->next = Mc->next;
    Mc->next = tmpM;
}

void OutPutMultinomial(Multinomial M)
{
    //输出多项式
    Multinomial p = M->next;
    cout << "多项式为:\n";
    while (p->next)
    {
        if (p->next->CCs > 0)
            cout << p->CCs << "X^" << p->exp << "+";
        else
            cout << p->CCs << "X^" << p->exp;
        p = p->next;
    }
    cout << p->CCs << "X^" << p->exp << endl;
}

int main()
{
    Multinomial Ma, Mb, Mc;
    CreateMultinomial(Ma);
    CreateMultinomial(Mb);
    MergepMultinomial(Ma, Mb, Mc);
    OutPutMultinomial(Mc);
    return 0;
}
很抱歉本人可用分为0没办法给各位加分。。希望各位高手体谅一下。。。

[ 本帖最后由 Vi_No 于 2010-3-27 01:06 编辑 ]
搜索更多相关主题的帖子: 单链 
2010-03-26 16:08
玩出来的代码
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:河南新乡
等 级:贵宾
威 望:11
帖 子:742
专家分:2989
注 册:2009-10-12
得分:0 
创建链表时指针也是按值传递的,并没有改变它的指向,改成引用吧,

 if(pa==NULL || pa==NULL) return ;            //加上这句判断一下,记得释放申请的空间、
  pc = (Multinomial)malloc(sizeof(LNode));
    pc = tmpM = pa ? pa : pb;
    while (pc->next)
        pc = pc->next;
    pc->next = Mc->next;
    Mc->next = tmpM;

离恨恰如春草,更行更远还生。
2010-03-26 23:23
Vi_No
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2009-5-15
得分:0 
回复 2楼 玩出来的代码
引用试过结果一样的。。
而且相同的算法我用来实现单链表合并没问题。。
2010-03-26 23:37
玩出来的代码
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:河南新乡
等 级:贵宾
威 望:11
帖 子:742
专家分:2989
注 册:2009-10-12
得分:0 
你把改过的代码贴出来,我测试的时候就好好的。

离恨恰如春草,更行更远还生。
2010-03-27 00:04
玩出来的代码
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:河南新乡
等 级:贵宾
威 望:11
帖 子:742
专家分:2989
注 册:2009-10-12
得分:0 
以下是引用玩出来的代码在2010-3-26 23:23:16的发言:

创建链表时指针也是按值传递的,并没有改变它的指向,改成引用吧,

 if(pa==NULL || pa==NULL) return ;            //加上这句判断一下,记得释放申请的空间、
  pc = (Multinomial)malloc(sizeof(LNode));
    pc = tmpM = pa ? pa : pb;
    while (pc->next)
        pc = pc->next;
    pc->next = Mc->next;
    Mc->next = tmpM;
那句写错了,应该是
if(pa==NULL && pb==NULL) return ;

离恨恰如春草,更行更远还生。
2010-03-27 00:05
Vi_No
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2009-5-15
得分:0 
回复 5楼 玩出来的代码
之前就是引用的。所以我很不理解就瞎改了。
2010-03-27 00:10
玩出来的代码
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:河南新乡
等 级:贵宾
威 望:11
帖 子:742
专家分:2989
注 册:2009-10-12
得分:0 
程序代码:
#include <iostream>

using namespace std;                                ///看看好用不好。

typedef struct LNode
{
    int CCs;
    int exp;
    struct LNode *next;
}LNode, *Multinomial;

void CreateMultinomial(Multinomial &M)
{
    //创建链表
    M = (Multinomial)malloc(sizeof(LNode));
    M->next = NULL;
    Multinomial p;
    int i;
    cout << "请输入多项式的项数:\n";
    cin >> i;
    cout << "请依次输入多项式的系数和指数:\n";
    for (; i>0; i--)
    {
        p = (Multinomial)malloc(sizeof(LNode));
        cin >> p->CCs >> p->exp;
        p->next = M->next;
        M->next = p;
    }
}

void MergepMultinomial(Multinomial &Ma, Multinomial &Mb, Multinomial &Mc)
{
    //合并多项式
    Multinomial pa = Ma->next,    //报错这个指令引用的内存不能为"read".
        pb = Mb->next, pc, tmpM;
        Mc = (Multinomial)malloc(sizeof(LNode));
        Mc->next = NULL;
    int tmp;
    while (pa && pb)
    {
        pc = (Multinomial)malloc(sizeof(LNode));
        if (pa->exp == pb->exp)
        {
            tmp = pa->CCs + pb->CCs;
            if (tmp)
            {
                pc->CCs = tmp;
                pc->exp = pa->exp;
                pc->next = Mc->next;
                Mc->next = pc;
                pa = pa->next;
                pb = pb->next;
            }
        }
        else if (pa->exp < pb->exp)
        {
            pc->CCs = pa->CCs;
            pc->exp = pa->exp;
            pc->next = Mc->next;
            Mc->next = pc;
            pa = pa->next;
        }
        else
        {
            pc->CCs = pb->CCs;
            pc->exp = pb->exp;
            pc->next = Mc->next;
            Mc->next = pc;
            pb = pb->next;
        }
    }
    if(pa==NULL && pb==NULL) return ;
    pc = (Multinomial)malloc(sizeof(LNode));
    pc = tmpM = pa ? pa : pb;
    while (pc->next)
        pc = pc->next;
    pc->next = Mc->next;
    Mc->next = tmpM;
}

void OutPutMultinomial(Multinomial M)
{
    //输出多项式
    Multinomial p = M->next;
    cout << "多项式为:\n";
    while (p->next)
    {
        if (p->next->CCs > 0)
            cout << p->CCs << "X^" << p->exp << "+";
        else
            cout << p->CCs << "X^" << p->exp;
        p = p->next;
    }
    cout << p->CCs << "X^" << p->exp << endl;
}

int main()
{
    Multinomial Ma, Mb, Mc;
    CreateMultinomial(Ma);
    CreateMultinomial(Mb);
    MergepMultinomial(Ma, Mb, Mc);
    OutPutMultinomial(Mc);
    return 0;
}

离恨恰如春草,更行更远还生。
2010-03-27 00:16
Vi_No
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2009-5-15
得分:0 
回复 7楼 玩出来的代码
我觉得很诡异。。我最初的代码除了你添加的那一句其他都一样的。但是就是会出错。刚刚突然可以了。
求解释。。
2010-03-27 00:23
玩出来的代码
Rank: 11Rank: 11Rank: 11Rank: 11
来 自:河南新乡
等 级:贵宾
威 望:11
帖 子:742
专家分:2989
注 册:2009-10-12
得分:0 
排除错误嘛,,
 pc = tmpM = pa ? pa : pb;         //若pa,pb都为空 那pc一定为空,下面的那个while又用了pc->next,,自然出错了
    while (pc->next)
        pc = pc->next;

离恨恰如春草,更行更远还生。
2010-03-27 00:29
Vi_No
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2009-5-15
得分:0 
回复 9楼 玩出来的代码
但是这只是两个多项式完全相同的情况啊。不同应该不影响吧。
而且报错的指令是函数的第一句。。

[ 本帖最后由 Vi_No 于 2010-3-27 00:33 编辑 ]
2010-03-27 00:31



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




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

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