C语言中数组作为函数参数的示例分析

本文主要介绍"C语言中数组作为函数参数的示例分析",希望能够解决您遇到有关问题,下面我们一起来看这篇 "C语言中数组作为函数参数的示例分析" 文章。

数组作为函数参数

1 冒泡排序函数的错误设计

冒泡排序的核心思想:

相邻的两元素进行比较,有需要的话就交换

C语言中数组作为函数参数的示例分析

#include <stdio.h>
void bubble_sort(int arr[])
{
	int sz = sizeof(arr)/sizeof(arr[0]);//这样对吗?
	int i = 0;
	for(i=0; i<sz-1; i++)//sz-1趟冒泡排序
	{
		int j = 0;
		for(j=0; j<sz-i-1; j++)
		{
			if(arr[j] > arr[j+1])
			{
				//交换
				int tmp = arr[j];
				arr[j] = arr[j+1];
				arr[j+1] = tmp;
			}
		}
	}
}
int main()
{
	int arr[] = {3,1,7,5,8,9,0,2,4,6};
	bubble_sort(arr);//是否可以正常排序?
	for(i=0; i<sizeof(arr)/sizeof(arr[0]); i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

2 数组名是什么?

数组传参的实质不是传整个数组,而是首元素的地址

bubble_sort函数中的sizeof(arr)算出的是指针的大小,因此导致错误

arr本质是首元素地址,数组接收时也可以用int *arr代替int arr[]

特殊情况:

1.&arr

C语言中数组作为函数参数的示例分析

2.sizeof(数组名),计算整个数组的大小,sizeof内部单独放一个数组名,数组名表示整个数组

3 冒泡排序函数的正确设计

void bubble_sort(int arr[], int sz)//参数接收数组元素个数
{
	//代码同上面函数
	int i = 0;
	for(i=0; i<sz-1; i++)//sz-1趟冒泡排序
	{
		int j = 0;
		for(j=0; j<sz-i-1; j++)
		{
			if(arr[j] > arr[j+1])
			{
				int tmp = arr[j];
				arr[j] = arr[j+1];
				arr[j+1] = tmp;
			}
		}
	}
}
int main()
{
	int arr[] = {3,1,7,5,8,9,0,2,4,6};
	int sz = sizeof(arr)/sizeof(arr[0]);
	bubble_sort(arr, sz);//是否可以正常排序?
	for(i=0; i<sz; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

关于 "C语言中数组作为函数参数的示例分析" 就介绍到这。希望大家多多支持编程宝库

C语言如何实现数组越界:本文主要介绍"C语言怎么实现数组越界",希望能够解决您遇到有关问题,下面我们一起来看这篇 "C语言怎么实现数组越界" 文章。数组越界数组的下标是有范围限制的。数组的下规定是从0开始的,如果数组有n个元素,最后一个元素 ...