标题:一个菜鸟的白痴问题。单链表
取消只看楼主
Vi_No
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2009-5-15
结帖率:100%
 问题点数:0 回复次数:6 
一个菜鸟的白痴问题。单链表
各位同为菜鸟的同学好。数据结构的作业还是要自己做的。如果不会可以像本人一样求助。但是千万不要抄袭代码。因为抄袭不会帮助你提高。而且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
Vi_No
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2009-5-15
得分:0 
回复 2楼 玩出来的代码
引用试过结果一样的。。
而且相同的算法我用来实现单链表合并没问题。。
2010-03-26 23:37
Vi_No
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2009-5-15
得分:0 
回复 5楼 玩出来的代码
之前就是引用的。所以我很不理解就瞎改了。
2010-03-27 00:10
Vi_No
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2009-5-15
得分:0 
回复 7楼 玩出来的代码
我觉得很诡异。。我最初的代码除了你添加的那一句其他都一样的。但是就是会出错。刚刚突然可以了。
求解释。。
2010-03-27 00:23
Vi_No
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2009-5-15
得分:0 
回复 9楼 玩出来的代码
但是这只是两个多项式完全相同的情况啊。不同应该不影响吧。
而且报错的指令是函数的第一句。。

[ 本帖最后由 Vi_No 于 2010-3-27 00:33 编辑 ]
2010-03-27 00:31
Vi_No
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2009-5-15
得分:0 
回复 11楼 玩出来的代码
我想我当时输入的指数应该不是完全相同的。。
无解无解。
2010-03-27 00:44
Vi_No
Rank: 1
等 级:新手上路
帖 子:27
专家分:0
注 册:2009-5-15
得分:0 
回复 13楼 玩出来的代码
我说的相同和你指的是一样的。。

不过还是谢谢你了。(本人真的没分给不好意思)
2010-03-27 01:00



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




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

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