【问题标题】:simple 2D array matrix in c++C ++中的简单二维数组矩阵
【发布时间】:2019-11-13 16:24:05
【问题描述】:

我绝对是 cpp 的新手,我尝试编写一个简单的二维数组矩阵。 这就是我要说的:


#include <iostream>
#include <string>

using namespace std;


void printTable()
{

    int tabelle [10][10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
    int i, j;
    for (i = 0; i < 10; i++)
    {
        for (j = 0; j < 10; j++)
        {
            printf("%d   ", tabelle[i][j]);
        }
        printf("\n");
    }
}


int main(int argc, char* argv[])
{
    printTable();


    return 0;
}

它是这样的:

1 2 3 4 5 6 7 8 9 10
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0

它应该是这样的:

1 2 3 4 5 6 7 8 9 10
2 0 0 0 0 0 0 0 0 0
3 0 0 0 0 0 0 0 0 0
4 0 0 0 0 0 0 0 0 0
5 0 0 0 0 0 0 0 0 0
6 0 0 0 0 0 0 0 0 0
7 0 0 0 0 0 0 0 0 0
8 0 0 0 0 0 0 0 0 0
9 0 0 0 0 0 0 0 0 0
10 0 0 0 0 0 0 0 0 0

感谢任何建议:D

【问题讨论】:

  • 您需要正确初始化数组。只有数组的前 10 个元素由您初始化(1 到 10),其余的由编译器初始化为零。看看这个具体情况是这样的: int tabelle [10][10] = { {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10} };我在您的初始化周围添加了大括号,现在更容易将其视为 2d 数组的第一行,其余为零。

标签: c++ arrays matrix 2d


【解决方案1】:

这不是 C++ 中数组赋值的工作方式。 将二维数组视为一维数组的一维数组。

int tabelle[10][10] = {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}, {2, 0, 0, 0, 0, 0, 0, 0, 0, 0}, {3, 0, 0, 0, 0, 0, 0, 0, 0, 0}, {4, 0, 0, 0, 0, 0, 0, 0, 0, 0}, {5, 0, 0, 0, 0, 0, 0, 0, 0, 0}, {6, 0, 0, 0, 0, 0, 0, 0, 0, 0}, {7, 0, 0, 0, 0, 0, 0, 0, 0, 0}, {8, 0, 0, 0, 0, 0, 0, 0, 0, 0}, {9, 0, 0, 0, 0, 0, 0, 0, 0, 0}, {10, 0, 0, 0, 0, 0, 0, 0, 0, 0}};

【讨论】:

  • FWIW {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}, {2}, {3}, {4}, {5}, {6}, {7}, {8}, {9}, {10}}; 做同样的事情
【解决方案2】:
  • 您的代码工作正常,二维数组设置为一维 数组。
  • 这里二维数组 tableelle[10][10] 的第一个一维数组 tablelle[0] 用元素初始化。
  • 另一件事是部分初始化的数组用
    填充元素的其余部分 零,这就是所有其他元素都为零的原因。

【讨论】:

    【解决方案3】:

    有几种不同的方法可以初始化二维数组,结果相同:

        int tab[4][4] = {{1,2,3,4},{2},{3},{4}};
        int bat[4][4] = {1,2,3,4,2,0,0,0,3,0,0,0,4,0,0,0};
    

    要记住的是,这种数组是由编译器自动分配到栈上的,并作为线性顺序数组存储在内存中(见上面的第二种方法)。

    此外,对于 C++,您以这种方式通过自动分配在函数中创建的数组的范围仅限于该函数;函数调用结束后,数组就消失了。如果要在函数中创建数组并传回主函数使用,则必须动态(堆)分配;然后将指向该数组的指针传递回 main,然后您必须手动管理该内存(假设您没有使用智能指针来创建它)。

    注意:对于非常大的数组,您还可以按如下方式启动数组:

       myarray[100][100] = {};    //sets all elements to 0
       for (int i = 0; i < 100; i++) {
           myarray[0][i] = i + 1;
           myarray[i][0] = i + 1;
       }
    

    永远不要这样做:

        myarray[100][100];
    

    因为这会创建一个充满垃圾值的数组,其中加载了之前恰好存储在该内存位置中的任何随机位,您以后可能会忘记覆盖它们。

    【讨论】:

    • 非常感谢像你这样的人我能够更好地理解它^^
    猜你喜欢
    • 2011-05-28
    • 2021-07-18
    • 1970-01-01
    • 2016-08-13
    • 1970-01-01
    • 1970-01-01
    • 2018-08-21
    • 2015-09-25
    相关资源
    最近更新 更多