我正在为C ++上的稀疏矩阵开发ADT(使用Visual C ++ 2012)
这是我的班级定义:
类Class包含一个单元格数组(每个单元格包含一个行号,一个列号和一个非零值)
编辑:我认为问题最多的是复制构造函数,所以我在这里添加了构造函数:
class Sparce
{
friend std::ostream & operator <<(std::ostream& os, Sparce &sprc);
Cell * cells;
int row;
int col;
int value;
public:
Sparce(int ** a , int r, int c);
Sparce( const Sparce & a )
{
cells = new Cell[a.value];
setRow(a.row);
setCol(a.col);
setValue(a.value);
for (int i = 0; i < value; i++)
{
cells[i].setCell(a.cells[i].getRow(),a.cells[i].getCol(),a.cells[i].getValue());
}
}
Sparce (int r , int c , int val);
~Sparce(void);
int getRow();
int getCol();
int getValue();
void setRow(int r);
void setCol(int c);
void setValue(int v);
int getRowX(int i);
int getRowY(int i);
int getRowValue(int i);
Sparce operator+ (Sparce sp2);
};
细胞定义是:
class Cell
{
public:
Cell(int r , int c , int v);
Cell();
int getRow();
int getCol();
int getValue();
void setCell(int r , int c , int v);
void setRow(int r);
void setCol(int c);
void setValue(int v);
private:
int row;
int col;
int value;
};
似乎我的+运算符不起作用,我在运算符的返回行上遇到运行时错误:
Sparce Sparce::operator+ (Sparce sp2)
{
if(getRow() != sp2.getRow() || getCol() != sp2.getCol())
throw std::exception("For adding to array most have same rows and coloumns");
int k1 = 0 , k2 = 0 , k3 = 0;
//counting number of none zero value for result
while (k1 < getRow() && k2<sp2.getRow())
{
if(getRowX(k1) < sp2.getRowX(k2))
{
k1++;
k3++;
}
else if(getRowX(k1) > sp2.getRowX(k2))
{
k2++;
k3++;
}
else if(getRowX(k1) == sp2.getRowX(k2))
{
if (getRowY(k1) < sp2.getRowY(k2))
{
k1++;
k3++;
}
else if(getRowY(k1) > sp2.getRowY(k2))
{
k2++;
k3++;
}
else if(getRowX(k1) == sp2.getRowX(k2))
{
k1++;
k2++;
k3++;
}
}
}//while
while(k1<getValue())
{
k1++;
k3++;
}
while(k2<sp2.getValue())
{
k2++;
k3++;
}
//end counting
k3--;//we will count one extra ++ , so We should reduce it.when i comment this line there will be no run time error and correct answer but an extra line in result
Sparce res(getRow(),getCol(),k3);
k1 = 0;
k2 = 0;
k3 = 0;
while (k1 < getRow() && k2<sp2.getRow())
{
if(getRowX(k1) < sp2.getRowX(k2))
{
res.cells[k3].setCell(getRowX(k1),getRowY(k1),getRowValue(k1));
k1++;
k3++;
}
else if(getRowX(k1) > sp2.getRowX(k2))
{
res.cells[k3].setCell(sp2.getRowX(k2),sp2.getRowY(k2),sp2.getRowValue(k2));
k2++;
k3++;
}
else if(getRowX(k1) == sp2.getRowX(k2))
{
if (getRowY(k1) < sp2.getRowY(k2))
{
res.cells[k3].setCell(getRowX(k1),getRowY(k1),getRowValue(k1));
k1++;
k3++;
}
else if(getRowY(k1) > sp2.getRowY(k2))
{
res.cells[k3].setCell(sp2.getRowX(k2),sp2.getRowY(k2),sp2.getRowValue(k2));
k2++;
k3++;
}
else if(getRowX(k1) == sp2.getRowX(k2))
{
res.cells[k3].setCell(sp2.getRowX(k2),sp2.getRowY(k2),getRowValue(k1)+sp2.getRowValue(k2));
k1++;
k2++;
k3++;
}
}
}//while
while(k1<getValue())
{
res.cells[k3].setCell(getRowX(k1),getRowY(k1),getRowValue(k1));
k1++;
k3++;
}
while(k2<sp2.getValue())
{
res.cells[k3].setCell(sp2.getRowX(k2),sp2.getRowY(k2),sp2.getRowValue(k2));
k2++;
k3++;
}
return res;
}
编辑:当我在我的代码中评论最后一个k3--(我已在该行添加注释)问题将被解决,但结果将有一个额外的行
可能是什么问题?
感谢。
答案 0 :(得分:0)
您将复制构造函数声明为采用非const引用。复制构造函数通常应该采用const引用。有可能发生某些事情正在调用operator +,这会使编译器使用默认的const-ref复制构造函数(浅层复制指针)。
也可能无法正确编写复制构造函数或析构函数。
提示:您是否考虑过使用std :: vector来保存数组?然后你不必担心照顾指针。