1

所以我花了无数个小时试图找到这个问题的答案。我发现了一些接近它的东西,但不完全是,所以我想我会在这里发帖。

我正在尝试创建一个二维结构数组。我将调用一个函数来创建结构并将值输入到结构中。这是一个可能的输出示例:

输入:int 5,int 5

1 2 3 4 5
2 4 6 8 10
3 6 9 12 15
4 8 12 16 20
5 10 15 20 25

我能够创建结构,但是当我尝试输入值时我的程序不断崩溃。任何输入都会很棒!下面是我的代码。

struct values{
int mult;
float div;
};

values** create_table(int row, int col){
values** tab = new values*[row];
values* one_row = new values[col];
for (int i = 0; i < row; i++){
    tab[i] = one_row;
}
return tab;
}

void set_m_values(values** tab, int row, int col){
for (int i = 0; i < row; i++){
    for (int j = 0; i < col; j++){
        tab[i][j].mult = (i+1)*(j+1);
    }
}
}

int main() {
int row = 5;
int col = 5;
values** tab = create_table(row, col);
set_m_values(tab, row, col);
for (int i = 0; i < row; i++){
    for (int j = 0; j< col; j++){
        cout <<tab[0][i].mult;
    }
    cout <<endl;
}
return 0;
}
4

1 回答 1

3

你的初始化是错误的

values* one_row = new values[col];
for (int i = 0; i < row; i++){
    tab[i] = one_row;

这是创建一行,并将其分配给每一行。

您可能打算这样做:

values** tab = new values*[row];

for (int i = 0; i < row; i++)
{
    tab[i] = new values[col];
}

话虽这么说,您确实应该使用std::arrayor std::vector

另外,这就是导致崩溃的原因,在 中set_m_values,您的比较不正确:

for (int j = 0; i < col; j++){ // notice the i in there

应该:

for (int j = 0; j < col; j++){ // replaced i with j

很可能您复制粘贴并忘记更改它。我想强调一个事实,你真的应该为此使用像 vector 这样的标准库容器。例如,您可以:

// with this you don't need the create_table function
std::vector< std::vector<values> > table(row, std::vector<values>(col));

PS:您的代码中有内存泄漏,因为没有调用删除。这不是你会遇到的问题std::vector

于 2013-08-10T02:03:43.390 回答