MyException - 我的异常网
当前位置:我的异常网» C++ » 这个程序编译没异常,但运行有一点小异常,希望大家

这个程序编译没异常,但运行有一点小异常,希望大家帮小弟我一把

www.MyException.Cn  网友分享于:2013-04-27  浏览:7次
这个程序编译没错误,但运行有一点小错误,希望大家帮我一把。
这个题的题目是这样的:
  建立一个二维数组类Douary,使该类中有以下数据成员、成员函数及友员函数,完成矩阵的输入、输出、加、减、相等判断等操作。

C/C++ code

#include <iostream.h>
class Douary
{
public:
    Douary(int m, int n);//构造函数:用于建立动态数组存放m行n列的二维数组(矩阵)元素,并将该数组元素初始化为
    ~Douary(); //析构函数:用于释放动态数组所占用的存储空间。
    Douary(const Douary &d);//复制构造函数  //此处增加一个复制构造函数
    friend istream &operator>>(istream &input, Douary &d);//重载运算符“>>”输入二维数组,其中d为Dousry类对象;
    friend ostream &operator<<(ostream &output, Douary &d);//重载运算符“<<”以m行n列矩阵的形式输出二维数组,其中d为Douary类对象。
    friend Douary operator+(const Douary &d1,const Douary &d2);//两个矩阵相加,规则:对应位置上的元素相加
    friend Douary operator-(const Douary &d1,const Douary &d2);//两个矩阵相减,规则:对应位置上的元素相减
    bool operator==(const Douary &d);//判断两个矩阵是否相等,即对应位置上的所有元素是否相等
private:
    int * Array;      //Array 为动态数组指针。
    int row;          //row  为二维数组的行数。
    int col;          //col   为二维数组的列数。
};
Douary::Douary(int m, int n)//构造函数:用于建立动态数组存放m行n列的二维数组(矩阵)元素,并将该数组元素初始化为  
{  
    int s;
    row=m;  
    col=n;
    s=row*col;
    if((m|n) != 0 )  
    {  
        Array=new int[s];  
        for (int i=0;i<s;i++)  
        {  
            *(Array+i) = 0;  
        }  
    }  
    else  
        Array = NULL;  
}  
Douary::Douary(const Douary &d)  
{  
    row=d.row;  
    col=d.col; 
    int s=row*col;
    Array = new int[s];  
    for(int j=0; j<s; ++j)  
        Array[j]=d.Array[j];    
}  
Douary::~Douary()  
{  
    if (Array != NULL)  
    {  
        for (int i=0;i<(row*col);i++)  
        {  
            delete (Array+i);  
        }  
        delete []Array;  
        //Array = NULL;  
    }  
}  

istream &operator>>(istream &input, Douary &d)//重载运算符“>>”输入二维数组,其中d为Dousry类对象;  
{  
    int s;
    s=d.row*d.col;
    //input>>d.row >>d.col ;  
    if((d.row|d.col) !=0)  
    {  
        int i;  
        for (i=0;i<s;i++)  
        {  
            input>>*(d.Array+i); 
        }
        
    }  
    else  
    {
        cout<<"您输入的数据有误!"<<endl; 
        
    } 
    return input;  
}
ostream &operator<<(ostream &output, Douary &d)//重载运算符“<<”以m行n列矩阵的形式输出二维数组,其中d为Douary类对象。  
{  
    //output<<d.row <<'/'<<d.col <<endl;
     for(int i=0; i<d.row; ++i)  
    {  
        for(int j=0; j<d.col; ++j)  
            cout<<*(d.Array+i*d.col+j)<<"\t";  
        cout<<endl;  
    }  
    cout<<endl;  
    return output;  
}  


Douary operator+(const Douary &d1,const Douary &d2)//两个矩阵相加,规则:对应位置上的元素相加  
{  
    Douary d(d1.row,d1.col);
    if (d1.row==d2.row && d1.col==d2.col)  
    {  
        
        int s=d1.row*d1.col;
        int j; 
        for(j=0;j<s;++j)  
        {  
            *(d.Array+j) = *(d1.Array+j)-*(d2.Array+j); 
        }  
    }  
    else  
    {  
        cout<<"d1和d2的行数与列数不相等!"<<endl;  
    }  
    return d;  
}  
Douary operator-(const Douary &d1,const Douary &d2)//两个矩阵相减,规则:对应位置上的元素相减  
{  
    Douary d(d1.row,d1.col);
    if (d1.row==d2.row && d1.col==d2.col)  
    {  
        int s=d1.row*d1.col;
        int j;    
        for(j=0;j<s;++j)  
        {  
            *(d.Array+j) = *(d1.Array+j)-*(d2.Array+j);  
        }  
    }  
    else  
    {  
        cout<<"d1和d2的行数与列数不相等!"<<endl;  
    }  
    return d;  
}  

bool Douary::operator==(const Douary &d)//判断两个矩阵是否相等,即对应位置上的所有元素是否相等  
{  
    bool bRet = false;  
    if (row==d.row && col==d.col)  
    {  
        int j; 
        int s=row*col;
        for(j=0;j<s;++j)  
            if(*(d.Array+j)!=*(Array+j))  
                return false;  
            bRet = true;  
    }  
    return bRet;  
}  

int main()
{
    Douary d1(2,3),d2(2,3);
    cout<<"输入d1(2,3):"<<endl;
    cin>>d1;
    cout<<"输入d2(2,3):"<<endl;
    cin>>d2;
    cout<<"d1="<<endl;
    cout<<d1;
    cout<<"d2="<<endl;
    cout<<d2;
    cout<<"d1+d2="<<endl;
    cout<<(d1+d2);
    cout<<"d1-d2="<<endl;
    cout<<(d1-d2);
    cout<<"d1"<<((d1==d2)?"==":"!=")<<"d2"<<endl;
    
    return 0;
}


文章评论

如何区分一个程序员是“老手“还是“新手“?
如何区分一个程序员是“老手“还是“新手“?
Java程序员必看电影
Java程序员必看电影
一个程序员的时间管理
一个程序员的时间管理
聊聊HTTPS和SSL/TLS协议
聊聊HTTPS和SSL/TLS协议
那些争议最大的编程观点
那些争议最大的编程观点
Web开发人员为什么越来越懒了?
Web开发人员为什么越来越懒了?
我是如何打败拖延症的
我是如何打败拖延症的
Web开发者需具备的8个好习惯
Web开发者需具备的8个好习惯
程序员的鄙视链
程序员的鄙视链
10个帮程序员减压放松的网站
10个帮程序员减压放松的网站
代码女神横空出世
代码女神横空出世
老程序员的下场
老程序员的下场
5款最佳正则表达式编辑调试器
5款最佳正则表达式编辑调试器
程序员必看的十大电影
程序员必看的十大电影
编程语言是女人
编程语言是女人
Java 与 .NET 的平台发展之争
Java 与 .NET 的平台发展之争
写给自己也写给你 自己到底该何去何从
写给自己也写给你 自己到底该何去何从
10个调试和排错的小建议
10个调试和排错的小建议
为什么程序员都是夜猫子
为什么程序员都是夜猫子
如何成为一名黑客
如何成为一名黑客
 程序员的样子
程序员的样子
十大编程算法助程序员走上高手之路
十大编程算法助程序员走上高手之路
程序员应该关注的一些事儿
程序员应该关注的一些事儿
每天工作4小时的程序员
每天工作4小时的程序员
鲜为人知的编程真相
鲜为人知的编程真相
漫画:程序员的工作
漫画:程序员的工作
我的丈夫是个程序员
我的丈夫是个程序员
科技史上最臭名昭著的13大罪犯
科技史上最臭名昭著的13大罪犯
团队中“技术大拿”并非越多越好
团队中“技术大拿”并非越多越好
旅行,写作,编程
旅行,写作,编程
看13位CEO、创始人和高管如何提高工作效率
看13位CEO、创始人和高管如何提高工作效率
为啥Android手机总会越用越慢?
为啥Android手机总会越用越慢?
程序员都该阅读的书
程序员都该阅读的书
“肮脏的”IT工作排行榜
“肮脏的”IT工作排行榜
程序员眼里IE浏览器是什么样的
程序员眼里IE浏览器是什么样的
初级 vs 高级开发者 哪个性价比更高?
初级 vs 高级开发者 哪个性价比更高?
做程序猿的老婆应该注意的一些事情
做程序猿的老婆应该注意的一些事情
程序员的一天:一寸光阴一寸金
程序员的一天:一寸光阴一寸金
亲爱的项目经理,我恨你
亲爱的项目经理,我恨你
老美怎么看待阿里赴美上市
老美怎么看待阿里赴美上市
当下全球最炙手可热的八位少年创业者
当下全球最炙手可热的八位少年创业者
中美印日四国程序员比较
中美印日四国程序员比较
程序员周末都喜欢做什么?
程序员周末都喜欢做什么?
总结2014中国互联网十大段子
总结2014中国互联网十大段子
程序员最害怕的5件事 你中招了吗?
程序员最害怕的5件事 你中招了吗?
软件开发程序错误异常ExceptionCopyright © 2009-2015 MyException 版权所有