鱼C论坛

 找回密码
 立即注册
查看: 1381|回复: 2

用C++搞数据结构,但不熟不太会写,向大家求教

[复制链接]
发表于 2014-10-19 20:31:55 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
#include <cstdlib>
#include <iostream>
//我用的compiler是微软的visual studio 2013 快爆炸了,帮忙一下吧
using namespace std;
#include "polynomial.h"    // 用这个头文件,主要就是要写这个,裡面用类实现多项式的表示,相加和相乘

int main(int argc, char *argv[])
{
        Polynomial<double> poly1, poly2;
        // polynomial #1
        poly1.newItem(Term<double>(5, 15));
        poly1.newItem(Term<double>(3, -6));
        poly1.newItem(Term<double>(2, -14));
        poly1.newItem(Term<double>(0, 13.2));
        cout << "Polynomial #1 = ";
        poly1.Print();
        // polynomial #2
        poly2.newItem(Term<double>(6, 10));
        poly2.newItem(Term<double>(3, 6));
        poly2.newItem(Term<double>(2, 4));
        poly2.newItem(Term<double>(1, -2));
        cout << "Polynomial #2 = ";
        poly2.Print();
        // addition
        poly1.Add(poly2);
        cout << "addition : ";
        poly1.Print();
        // multiplication
        poly1.Add(poly2);
        cout << "multiplication : ";
        poly1.Print();
        system("PAUSE");
        return 0;
}
以下是標頭檔的內容,我的想法是多相式是由"项"构成,是"项"所组成的一个表(a list of terms) 于是乎我用二个类(template型式) term 和 list  再定义多项式模块(template polynomial)
template <class T>
class List
{
private:
        int capacity;//size
        int nItems; // count of items in the list
        T *data;//pointer points to the 1st elements of List
public:
        List(int initCapacity) // constructor
        {
                capacity = initCapacity;
                data = new T[capacity];
                nItems = 0;
        }
        ~List(){ delete []List;
                 data = NULL;        } // destructor
        void newItem(T value) // add a new item at the end
        {

                nItem++;
                if (nItem == capacity){//If exceeding the capacity, allocate more needed memo
                        T *newlist = new T[2*capacity];
                        for (int i = 0; i <= nitem; i++){
                                *(newlist + i*sizeof(T)) = *(data + i*sizeof(T));
                                *(newlist + nitem*sizeof(T)) = value;
                        }
                        };
                else
                        *(newlist + nitem*sizeof(T)) = value;
        }
        T getItem(int index)  // retrieve an item
        {
                T item;
                item = *(data+index*sizeof(T));
                return item;
       
        }
};

template <class T> Polynomial:public List< Term<T> >
class Polynomial{

public:
        void Add(const Polynomial<T>& poly){
                int* old = this->data;
                int* oldinput = poly.data;
                while ((this->data != old + sizeof(T)*this->nItems) && (poly.data != oldinput + sizeof(T)*poly.nItems)){
                        if ((this->data).exp > (poly.data).exp)
                                this->data += sizeof(T);
                        else if (this->data.exp < (poly.data.exp){
                                for (int j = 0;j<)
                                poly.data += sizeof(T);
                        }
                        else
                                this->
                }
        };
        void Multi(const Polynomial<T>& poly){
        //这裡还没写出来,任何建议和想法都欢迎,在下于此先行谢过各位大侠
        };
        void Print(const Polynomial<T>& poly){
        //这裡还没写出来,任何建议和想法都欢迎,在下于此先行谢过各位大侠
        };

};


template <class T>
class Term {
public:
        friend polynomial<T>;
        Term(int exp,T coef){
                this->exp = exp;
                this->coef = coef;
        };
private:
        T coef;
        int exp;

};

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2014-10-20 18:30:07 | 显示全部楼层
首先你得类定义就有问题啊,考虑的不周到,多项式是初学者必会的一种用链表的应用,书上是有的,你这个功能就没有好好的实现,我看了下帮你改下。。。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

头像被屏蔽
发表于 2014-10-30 15:03:06 | 显示全部楼层
提示: 作者被禁止或删除 内容自动屏蔽
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-18 03:30

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表