c语言关于二维数组的函数 c语言二维数组函数怎么用

C语言二维数组的函数调用函数调用不能这么用,第36行 。C标准里面返回值是不能直接返回一个数组的,只能返回数组的首地址 。输出学生成绩和每科成绩那个函数 , 你可以定义一个全局变量数组,还有求平均值最好用float 或者double,用int会造成精度流失 。帮你调试了一下,大概就这样吧
C语言中如何将二维数组作为函数的参数传递在C语言中可以用二维数组作为实参或者形参 。
1、函数中用二维数组作为形参,函数声明中可以指定所有维数的大小 , 也可以省略第1维的维数如:
void f(int array[3][10]); //正确
void f(int array[][10]);//正确
上面的两种二维数组形参表示都是正确的 。
2、函数中用二维数组作为形参,不能把第2维或者更高维的大小省略,如下面的定义是不合法的:
void f(int array[][]); //错误
因为从实参传递来的是数组的起始地址,在内存中按数组排列规则存放(按行存放),而并不区分行和列,如果在形参中不说明列数,则系统无法决定应为多少行多少列 , 不能只指定一维而不指定第二维,下面写法是错误的:
void f(int array[3][]);//错误
3、二维数组作为实参传递时,必须保证实参第2维的维数与形参第2维的维数相同,因为必须要保证形参和实参的数据类型一致 。比如定义如下函数:
void f(int array[][10]);
可以将如下数组传递给函数f 。
int a[2][10] = {1,2,3,4};
int b[4][10] = {1};
c语言中 strcpy函数是否可以用于二维数组?可以的,二维数组本身就是由多个一维数组组成的,对二维数组其中的一维数组分别使用strcpy即可:
#include iostream
using namespace std;
void main()
{
char* str = "hello world!";
char arr[100][100];
strcpy(arr[0], str);
coutarr[0]endl; //输出hello world!
}
如果不是逐个一维数组拷贝,那可以使用memcpy函数:
【c语言关于二维数组的函数 c语言二维数组函数怎么用】#include iostream
using namespace std;
void main()
{
char* str = "hello world!";
char arr[100][100];
memcpy(arr,str,13);
coutarr[0]endl; //输出hello world!
}
C语言函数传递二维数组C语言如果给函数传递二维数组作为参数
先看一个传递二维数组的例子:
编译:
程序看着没有任何问题,但是编译器通不过,报错在处理二维数组参数a的时候,类型不兼容 。
C语言里面对二维数组的存储是按照一维数组来处理的 , 二维数组按照行展开的方式按顺序存储,例如在上面的例子中:
二维数组a的定义:
它等同于一维数值的定义:
因为他们的空间存储分配一样的 。
所以在利用二维数组作为参数传递时,必须指定二维数组的列数,否则函数无法勾画出二维数组的组织形式 。只有有了列长度,通过下标a[i][j]时才能得到正确的下标地址 , 即:
我们改一下上面的额foo函数定义:
编译运行:
这下就正常了 。
参数如上所列 。
我们看到,函数的参数声明改成了:
这个声明的含义是:
不过此时还是需要指定二维数组的列长度,不然函数内部还是无法使用二维下标去访问数组:
编译:
原因同前面方法1一致,如果要访问二维数组,必须指定列的长度,否则无法计算出该元素的地址,a[i][j]=a [ (i-1)*COLNUM + j ],如果没有COLNUM , 那么这个地址无法计算出来 。从形参的声明来说,a就是一个指针,指向一维数组的指针,而不是一个二维数组 。

推荐阅读