考研C语言刷题基础篇之数组(一)

目录

第一题:用数组作为参数实现冒泡排序

不用函数的冒泡排序

冒泡排序原理:

错误的数值传参冒泡排序

错误的原因 

就是什么是数组名

正确的数组传参的冒泡排序 

数组的地址和数组首元素的地址的区别 


第一题:用数组作为参数实现冒泡排序

不用函数的冒泡排序

冒泡排序原理:

一共经过n-1次排序:相邻之间两两作比较。交换位置

 

 

//数组作为参数实现冒泡排序

int main()
{
	int arr[] = { 10,9,8,7,6,5,4,3,2,1 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	for(int i=0;i<sz-1;i++)
	{
		for(int j=0;j<sz-1-i;j++)
		{
			if (arr[j] > arr[j + 1])
			{
				int tmp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = tmp;

			}
			
		}
	
	}
	for(int i=0;i<sz;i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;

}

 

错误的数值传参冒泡排序

我们将冒泡的实现封装成一个函数,这时我们发现出来,问题,打印的结果并没实现冒泡排序

//错误的数组作为参数实现冒泡排序
void bubble_sort(int arr[])
{
	int i = 0;
	int sz = sizeof(arr) / sizeof(arr[0]);
	for (int i = 0; i < sz - 1; i++)
	{
		for (int j = 0; j < sz - 1 - i; j++)
		{
			if (arr[j] > arr[j + 1])
			{
				int tmp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = tmp;

			}

		}

	}
}

int main()
{
	int arr[] = { 10,9,8,7,6,5,4,3,2,1 };
	
	bubble_sort(arr);
	int i = 0;
	for(i=0;i<10;i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;

}

 

错误的原因 

这是因为,有一个知识点需要补充。

就是什么是数组名

什么是数组名arr

  1. 数组名其实是地址,而且是首元素的地址
  2. 但是有两个特例不是首元素的地址
    1. sizeof(arr)这里不是首元素的地址,这里是整个数组的大小
    2. &arr,对数组取地址,这里不是对首元素取地址,这里是对数组取地址
  3. 除了这两个特例以外,其他的情况都是首元素的地址
  4. 数组是数组同样其实也是指针,因此可以用数组接收,也可以用指针接收

下面我们用的数组名arr传参,这里arr是首元素的地址。 

bubble_sort(arr);

参数传给

void bubble_sort(int arr[])
//也可以用
void bubble_sort(int* arr)

 被下面的调用,但是由于arr是首元素的地址,所以sizeof(arr)求出的是首元素的大学4字节,

sizeof(arr【0】)也是首元素的地址4字节。所以这是式子的结果为1;并非实际大小10.

	int sz = sizeof(arr) / sizeof(arr[0]);

正确的数组传参的冒泡排序 

//正确的数组作为参数实现冒泡排序
void bubble_sort(int arr[],int sz)
{
	int i = 0;
	for (int i = 0; i < sz - 1; i++)
	{
		for (int j = 0; j < sz - 1 - i; j++)
		{
			if (arr[j] > arr[j + 1])
			{
				int tmp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = tmp;

			}

		}

	}
}

int main()
{
	int arr[] = { 10,9,8,7,6,5,4,3,2,1 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	bubble_sort(arr,sz);
	int i = 0;
	for(i=0;i<10;i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;

}

数组的地址和数组首元素的地址的区别 

虽然数组名在一些情况相当于数组首元的地址,但是这并不能代表数组的地址等于数组首元素的地址。

 下面我们可以看出,数组名和数组首元素还有数组的地址的地址是一样的

 而当我们对数组的地址和数组首元素的地址+1之后,就会发现他们并不一样。

我们发现数组名+1,和数组首元素+1,相当于地址加了4,这是应为他们加一相当于跳过了一位元素,四个字节。

而数组的地址加一,相当于整个数组10个元素都+1,那么就加了40个字节的地址。

 

相关推荐

  1. 荒原梦·数学:2025 每日(002)

    2024-01-25 07:56:06       65 阅读
  2. C语言

    2024-01-25 07:56:06       57 阅读
  3. c语言

    2024-01-25 07:56:06       57 阅读
  4. C语言

    2024-01-25 07:56:06       67 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-25 07:56:06       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-25 07:56:06       100 阅读
  3. 在Django里面运行非项目文件

    2024-01-25 07:56:06       82 阅读
  4. Python语言-面向对象

    2024-01-25 07:56:06       91 阅读

热门阅读

  1. MySQL 事务

    2024-01-25 07:56:06       57 阅读
  2. MySQL中的ON DUPLICATE KEY UPDATE语句详解

    2024-01-25 07:56:06       55 阅读
  3. Mybtisplus对时间字段进行自动填充

    2024-01-25 07:56:06       64 阅读
  4. 基于物联网的智能植物养护系统的设计与实现

    2024-01-25 07:56:06       56 阅读
  5. springboot的服务定位模式

    2024-01-25 07:56:06       56 阅读
  6. 前端页面直接导出Excel方案

    2024-01-25 07:56:06       57 阅读
  7. arm 汇编调用C

    2024-01-25 07:56:06       53 阅读
  8. ssh: connect to host github.com port 22: Connection timed out

    2024-01-25 07:56:06       49 阅读
  9. hadoop 三种运行方式

    2024-01-25 07:56:06       55 阅读
  10. centos下安装mongo C & C++ 驱动

    2024-01-25 07:56:06       56 阅读