我正在尝试构建一个适用于宽度矩阵的类。在它的构造函数中,它想知道数组的高度和宽度,并且它想要数组本身,然后它必须能够打印数组并重载一些运算符。Array 必须是浮点数组。这就是我到目前为止所拥有的:两个定义的参数:
#define HEIGHT 3
#define WIDTH 3
制作数组:
void Assignment_1::start(){
float **matrix = new float *[HEIGHT];
for (int i = 0; i < HEIGHT; i++){
matrix[i] = new float[WIDTH];
}
// 5 6 11
// 7 2 8
// 5 1 4
matrix[0][0]=5;
matrix[0][1]=6;
matrix[0][2]=11;
matrix[1][0]=7;
matrix[1][1]=2;
matrix[1][2]=8;
matrix[2][0]=5;
matrix[2][1]=1;
matrix[2][2]=4;
Matrix * matrixA = new Matrix(HEIGHT,WIDTH,matrix);
matrixA->printMatrix();
}
现在我知道一个 C++ 二维数组存在一个普通的 HEIGHT 指针数组,每个指针都指向一个 WIDTH 大小的数组。
构造函数和全局变量:
Matrix::Matrix(int width, int height, float **array){
this->height = height;
this->width = width;
this->array = array;
}
//in Matrix.h:
int width, height;
float ** array;
到此为止,一切都很好。现在我想通过打印来实际使用数组:
void Matrix::printMatrix(){
for (int h = 0; h < height; h++){
for (int w = 0; w < width;w++){
std::cout <<array[height][width]<<" ";
}
std::cout << std::endl;
}
}
这就是它出错的地方:程序简单地崩溃了。我有点明白为什么它崩溃了:我想我需要得到 array[h] 指向的内容(这是一个大小宽度的浮点数组),但试图这样做会给我错误:无法将 float* 转换为 float[] *。我需要做什么?