当前位置:首页 » 编程语言 » c语言把数组作为参数

c语言把数组作为参数

发布时间: 2023-05-02 02:11:01

‘壹’ c语言 数组做参数

#include<stdio.h>
void山信fun(inta[10])
{
intt,i;
for(i=0;i<5;i++)
{余誉
t=a[i];
a[i]=a[5+i];
a[5+i]竖唯段=t;
}
}
voidmain()
{
intc[10]={1,2,3,4,5,6,7,8,9,10},i;
fun(c);
for(i=0;i<10;i++)
printf("%d,",c[i]);
printf(" ");
}

‘贰’ C语言 数组做参数

strcmp的参数里p[j]和p[j+1]是指针数组的元素,里面存放的是字符串的首地址。在c语言中,字符串都是用首地址来表示的,所以可以吧指针数组中的地址值说成是代表字符串。

‘叁’ C语言中如何将二维数组作为函数的参数传递

在C语言中可以用二维数组作为实参或者形参。


1、函数中用二维数组作为形参,函数声明中可以指定所有维数的大小,也可以省略第1维的维数如:

voidf(intarray[3][10]);//正确
voidf(intarray[][10]);//正确

上面的两种二维数组形参表示都是正确的。


2、函数中用二维数组作为形参,不能把第2维或者更高维的大小省略,如下面的定义是不合法的:

voidf(intarray[][]);//错误

因为从实参传递来的是数组的起始地址,在内存中按数组排列规则存放(按行存放),而并不区分行和列,如果在形参中不说明列数,则系统无法决定应为多少行多少列,不能只指定一维而不指定第二维,下面写法是错误的:

voidf(intarray[3][]);//错误

3、二维数组作为实参传递时,必须保证实参第2维的维数与形参第2维的维数相同,因为必须要保证形参和实参的数据类型一致。比如定义如下函数:

voidf(intarray[][10]);

可以将如下数组传递给函数f。

inta[2][10]={1,2,3,4};
intb[4][10]={1};

‘肆’ c语言中数组名作为函数参数

要将数组长度作为一个参数传给average函数,不能在average函数内部埋斗歼通过int arrLen = sizeof(a) / 4;来计算数组长度弯冲。因为float average(float a[10])就相当于float average(float *a) ,所以sizeof(a)恒等销悄于4,sizeof(a) / 4恒等于1。
应该这样:
float average(float a[10],int arrLen) {
float sumSco = 0;
for (int i = 0; i < arrLen; i++)
{
sumSco += a[i];
}
return sumSco / arrLen;
}

‘伍’ 在C语言中,数组作为参数,是怎样在函数之间传递的啊

数组作为参数是按地址传递的
数组名就是数组的首地址。因此在数组名作函数参数时所进行的传送只是地址的传送, 也就是说把实参数组的首地址赋予形参数组名。形参数组名取得该首地址之后,也就等于有了实在的数组。实际上是形参数组和实参数组为同一数组,共同拥有一段内存空间。

‘陆’ C语言数组当参数传递

在学习C语言的过程中遇到数组作为参数传递的问题

一维数组:

这样我们可以很顺利的在test去遍历这个数组a,当然我们还可能传递指针:

一般来数参数的传递是值传递,也就是说实参传给形参,形参发生改变时实参并不会改变,(单向)但是数组在传递的时候是地址传递,只要形参发生了变化,实参也会发生变化(双向)。

这样传递数组就会发现一个问题,我没有办法获取到数组的长度。获取数组的长度我们一般用:

我们会发现n的值一直是2!为什么会这样呢!?
因为,a是函数参数,到了本函数中,a只是一个指针(地址,系统在本函数运行时,是不知道a所表示的地址有多大的数据存储空间,这里只是告诉函数:一个数据空间首地址),所以,sizoef(a)的结果是指针变量a占内存的大小,一般在64位机上是8个字节。int类型是4个字节,所以,结果永远是2,因此,我们要向获取数组长度要怎么办呢?

我可以在初始化数组的地方获取到数组的长度,作为参数传递过来:

这样做我们可以获取到数组的长度。

二维数组:

二维数组作为参数传递是后我们不可以像以为数组那样直接,如:

会发现编译都编译不通过,报“[Error] declaration of 'a' as multidimensional array must have bounds for all dimensions except the first”这个错,意思是多维数组的定义必须有一个除第一个之外的所有维度的边界,比如:

这样就OK了,但是我们是动态分配的数组不知道这个维度是多少的时候怎么办?这时候我们可以用指针当做一维数组来操作:

这样我们发现不能更灵活的去定位到某一行某一列,这样我们需要手工改变寻址方式:

‘柒’ C语言数组作为参数

int Arrage(int iArrage[10])这个函数的参数是iArrage,这是一个int型指针,所以要传一个int型指针进去,液姿凳比如main函数中的iStudent就是个闹旅int型指针册档

‘捌’ 在c语言中怎么将数组直接作为函数的参数 比如 int f(int a[10]) 在调用函数时会显示

要把数组作为函数的参数,在函数定义的时候,就要在参数列表设置数敬指针,裂尺因为数组名就肆毕高是数组的头指针,在调用时直接把数组名作为函数的参数就好了
比如
int fun(int *a)
{
//...
}
int main()
{
int a[10];
int result=fun(a);
return 0;
}
这样就好了
通常为了在函数中确保访问数组不越界,在参数列表还要假如数组的长度,方便函数访问数组
如下:
int fun(int *a,int length)
{
int i,sum=0;
for(i=0;i<length;i++)
{
//...对数组的每个元素进行访问
sum+=a[i];//把全部元素加起来
}
return sum;
}
int main()
{
int i,a[10];
for(i=0;i<10;i++)
scanf("%d",&a[i]);
int result=fun(a,10);
printf("总和为:%d\n",result);
return 0;
}

‘玖’ C语言数组作为形参实参的一些疑惑

void fun(int arr[], int n);

在函数定义的时候,形参int arr[]不是表示某个元素的值,而是告诉编译器第一个参数是一个数组指针,可以接收实参传过来的数组地址。

实际上以上定义等价于下面的定义。

1.数组里面带元素个数:

void fun(int arr[常数], int n);

这里的常数可以是任意正整数,实际上编译器是会忽略,因为这里只要告诉编译器我接收的是一个数组指针,至于它有多少个元素不关心,因为实参也只是传个地址过来。元素个数由参数二控制。至于为什么要这么约定可以看下面补充说明。

2.void fun(int *arr, int n);

使用指针,这种方式和题目中的方式是最常用的方式,第一种最不常用。

补充说明(为什么数组作为函数参数是传地址,而不是传每个元素):

设想一下,有一个函数如下

int fun(int nums[1000], int size)

它的参数一要处理1000多个元素的数组,如果是传值即每个元素,那在函数体内是不是就得再申请1000多个整数的内存,还需要把值从实参那里复制过来,这是非常耗时间的而且没有必要,因为在内存的某个块已经存放了这些数据。只要告诉放在哪个位置,你函数体去那里找就行了。这里说的就是传地址了,只需要传个数组首地址,然后告诉有多少个元素要处理就OK了。传地址只需要复制地址给形参,相对传每个元素快得多。

‘拾’ c语言中怎么用二维数组作为函数参数

二维数组作为函数参数,实参可以直接使用二维数组名,在被调用函数中对形参数组定义可以指定所有维数的大小,也可以省略第一维的大小说明,如:

因为从实参传递来的是数组的起始地址,如果在形参中不说明列数,编译器将无法定位元素的的位置。

热点内容
安卓模拟器10开配什么电脑 发布:2025-07-19 16:30:36 浏览:804
sql2008链接服务器 发布:2025-07-19 16:23:47 浏览:845
香港阿里腾讯云服务器报价 发布:2025-07-19 16:18:52 浏览:417
日语翻译存储安全 发布:2025-07-19 16:18:09 浏览:213
虚拟机访问主机ip 发布:2025-07-19 16:16:37 浏览:998
dz手机源码 发布:2025-07-19 16:14:50 浏览:704
如何利用服务器挂机器人 发布:2025-07-19 16:13:35 浏览:532
解压缩已 发布:2025-07-19 16:02:46 浏览:580
预处理编译链接 发布:2025-07-19 15:59:03 浏览:874
文件夹无限打开 发布:2025-07-19 15:57:01 浏览:277