在c++函数中使用2D数组

Use 2D array in a function C++

本文关键字:2D 数组 c++ 函数      更新时间:2023-10-16

我需要在c++ void函数中使用一个正方形2D数组(arr[n][n]),该函数创建一个拉丁正方形,但要求是n的大小在程序开始时不给定。用户必须输入数组的大小。我的代码示例(这是失败的):

    int n;
    void arrayz(int n , int arr[][])
    {
        for (int i = 0; i < n; i++)
            {
                for (int k = 0; k < n; k++)
                {
                    for (int e = 1; e <= n; e++)
                    {
                        arr[i][k] = e;
                    }
                }
            }
    }
    int main()
    {
            int arr[n][n];
            cin >> n;
            void arrayz (n, arr[n][n])
    }

请帮我解决这个问题!

您的代码有几个问题,而且不清楚您是否只是想为自己完成工作,所以我将尝试一种教学方法:

  1. 如前所述,如果您希望数组大小为用户输入,即动态分配,则需要malloc函数。然后将arr变量定义为int**,然后为其分配空间。

  2. 调用函数时不要写返回类型(最后一行void)

  3. 当发送数组c风格时,只发送地址-在这种情况下数组名称(arr, no [][])

  4. 当定义一个多维数组作为函数参数时,你必须至少提交第一个大小。你不知道它,因为它是用户给的,所以接受指针(例如int**)。

如果你不清楚如何进行这些调整,我建议你搜索一下C教程。

如前所述,您的实现是不可能的,因为n必须是恒定的,而事实并非如此。所以这里是<vector>的实现,其中n确实可以有任何(有效)值:

#include <iostream>
#include <vector>
void arrayz(std::vector<std::vector<int>> &vec){
    int count{ 0 };
    for (auto &x : vec){
        for (int i = 0; i < vec.size(); ++i){
            x[i] = (i + count) % vec.size() + 1;
        }
        ++count;
    }
}
int main(){
    std::size_t n{0};
    std::cout << "Type in the size of the 2d array: ";
    std::cin >> n;
    std::vector<std::vector<int>> vec(n, std::vector<int>(n));
    arrayz(vec);
    return 0;
}

如果你然后打印出vec:(示例运行)

Type in the size of the 2d array: 9
1 2 3 4 5 6 7 8 9
2 3 4 5 6 7 8 9 1
3 4 5 6 7 8 9 1 2
4 5 6 7 8 9 1 2 3
5 6 7 8 9 1 2 3 4
6 7 8 9 1 2 3 4 5
7 8 9 1 2 3 4 5 6
8 9 1 2 3 4 5 6 7
9 1 2 3 4 5 6 7 8

在c++中不能这样做。但是,您可以在C中这样做,因为C99:

#include <stdio.h>
void arrayz(int n , int arr[n][n]) {
    for (int i = 0; i < n; i++) {
        for (int k = 0; k < n; k++) {
            for (int e = 1; e <= n; e++) {
                arr[i][k] = e;
            }
        }
    }
}
int main() {
    int n;
    if(scanf(" %i", &n) != 1) return -1;
    int arr[n][n];
    arrayz (n, arr);
}

这是C,不是c++: c++要求所有数组类型的大小都是编译时常量,n不是。