C++函数调用二维数组

2024年11月22日 08:06
有4个网友回答
网友(1):

n如果是变量的话,数组编译时都通不过吧。数组分配时必须知道大小。
函数应该这样声明function(char array[10][10])或省略第一维的大小function(char array[][10])
function(char array[n][n])这样是错误的,数组的索引必须是个常量表达式
如果需要必须有cin决定大小,那就应该是动态分配的二位数组
char ** aa;
int n;
cin>>n;
aa = new char *[n];
for ( int i=0;i aa[i] = new char [n];
这样给函数传递参禅蔽拿数function((char**)array),但这样在实际的函并搭数调用是,我们就要进行强制转换才可以贺搭用;在函数调用时,要把数组形式写成指针形式如*((int*)array + n*i + j);直接写char array[i][j]会导致错误,编译可以通过,在VC编译器中执行会出现异常
建议楼主直接用vector容器,vector > 或vector

网友(2):

传槐顷递一个指向数组首地址的char * p指针,和 n
对烂明橡a[i][j]只能用*(p+i*n+j)饥旁操作

网友(3):

用动悄毁猜态数组,new 一余前个启型
http://baike.baidu.com/view/675652.htm

网友(4):

#include
#include <绝纳前iostream>

using std::vector;
using std::cout;
using std::cin;
using std::endl;

//函数调用
void f(vector > &a)
{
for (size_t i = 0; i < a.size(); i++)
{
for (size_t j = 0; j < a[i].size(); j++)
{
a[i][j] = 'c'; //当二维并清数组用
}
}
}
void main()
{
vector > a;
int n;
if( cin>>n && n >= 1)
{
for(int i = 0; i < n; i++)
{
a.push_back(vector(n));
}

f(a);

for (int i = 0; i < n; i++)
{
for (int j = 0; j < n; j++)
{
cout< }
cout< }
cout<茄高 }
}