C语言数组传入函数中
时间: 2024-09-09 20:17:20 浏览: 85
在C语言中,当数组作为参数传递给函数时,实际上是传递了数组的首地址。在函数内部,这个首地址被解释为指向数组第一个元素的指针。因此,函数中使用这个指针可以访问数组元素。需要注意的是,当数组作为参数传递时,函数接收的参数类型是指针类型,而不是数组类型,这是因为数组名本身就表示数组首元素的地址。
下面是一个简单的例子,展示了如何将数组传递给函数并打印数组中的每个元素:
```c
#include <stdio.h>
// 函数声明,接收一个整型数组和数组的大小
void printArray(int *arr, int size) {
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
printf("\n");
}
int main() {
int myArray[] = {1, 2, 3, 4, 5};
int size = sizeof(myArray) / sizeof(myArray[0]);
printArray(myArray, size); // 调用函数,传递数组和大小
return 0;
}
```
在这个例子中,`printArray` 函数接收一个整型指针 `arr` 和一个整数 `size` 作为参数。`arr` 实际上就是指向数组第一个元素的指针。函数内部使用指针来访问和打印数组中的每个元素。
相关问题
c语言数组传入函数是值传递还是引用传递
C语言中数组传入函数是以地址的形式进行传递,因此是引用传递。这意味着,当我们将一个数组作为参数传递给函数时,函数中对数组的任何修改都会影响到原始数组。
以下是一个示例代码,演示了C语言中数组作为参数的引用传递:
```c
#include <stdio.h>
void changeArray(int arr[], int size) {
int i;
for (i = 0; i < size; i++) {
arr[i] = arr[i] * 2;
}
}
int main() {
int arr[] = {1, 2, 3, 4, 5};
int size = sizeof(arr) / sizeof(arr[0]);
int i;
printf("原始数组:");
for (i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
changeArray(arr, size);
printf("\n修改后的数组:");
for (i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
输出结果为:
```
原始数组:1 2 3 4 5
修改后的数组:2 4 6 8 10
```
c语言数组排序函数
以下是一个简单的C语言数组排序函数的示例代码:
```
#include <stdio.h>
void sort(int arr[], int n) {
int i, j, temp;
for (i = 0; i < n-1; i++) {
for (j = 0; j < n-i-1; j++) {
if (arr[j] > arr[j+1]) {
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
int main() {
int arr[] = {5, 2, 9, 3, 6};
int n = sizeof(arr) / sizeof(arr[0]);
int i;
printf("Original array:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
sort(arr, n);
printf("Sorted array:\n");
for (i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
该函数使用冒泡排序算法对传入的数组进行排序。输入数组和数组长度作为函数参数传递。在主函数中,首先打印原始数组,然后调用sort函数对数组进行排序,最后再次打印排序后的数组。
阅读全文