(九十四)函数和二维数组

简介:

这两天见同学,四处跑,倒没太多空来安心学习,昨天到了三亚才能安心继续学习。

另外,本篇94是之前写的;

95涉及到字符串、地址、 指针等,比较复杂,所以花了好些时间来整理思路,总算搞明白了;

96今天刚刚完成的内容;

于是一起发出来,我再继续学函数和string对象。

————————————分割线————————————


二维数组的标准格式是:数组名[行数][列数]

在函数和指针的时候,我们将数组作为参数传递给函数的时候,是这样的:

void abc(int*变量名数组成员数);

也可以这样做:

void abc(int 变量名[], 数组成员数);

也就是说,在函数头和函数原型中,int *a和int a[]是一样的——*aa[]是相似的(也许?)

 

在传递二维数组的时候,函数头和函数原型中是这么写的,例如:

void abc (int a[][4],5);

这表示传递一个二维数组,a是指针,指针宽度是4int

这样的话,就相当于指出了二维数组的列数,而没有指明行数。

 

又因为上一篇的内容,所以实质上和void abc (int(*a)[4], 5); 这样的是等价的。但是,上面的a[][4]更直观一些。

 

如代码:

#include<iostream>
using namespace std;

//int sum(int a[][4], int);	//这个更直观,是(由4个元素组成的int数组)的地址
int sum(int(*a)[4], int);	//这个和上面的是等价的,就像(int *a)和(int a[])是等价的一样
void give(int a[][4], int);	//

int main()
{
	int a[5][4];	//声明二维数组
	give(a, 5);	//调用give函数,参数指针a(地址是a[0][0]),和参数5
	int total = sum(a, 5);
	cout << "total = " << total << endl;
	system("pause");
	return 0;
}


void give(int a[][4], int m)
{
	for (int i = 0;i < m;i++)	//循环行数
	{
		int n;
		for (n = 0;n < 4;n++)	//循环列数
		{
			a[i][n] = rand() & 10;	//赋值
			cout << "a[" << i << "][" << n << "] = " << a[i][n] << endl;
		}	
	}
}

int sum(int(*a)[4], int m)
{
	int total = 0;
	for (int i = 0;i < m;i++)	//循环行数
	{
		int n;
		for (n = 0;n < 4;n++)	//循环列数
		{
			total = total + a[i][n];	//相加
		}
	}
	return total;
}

输出:


a[0][0] = 8
a[0][1] = 2
a[0][2] = 10
a[0][3] = 0
a[1][0] = 0
a[1][1] = 8
a[1][2] = 2
a[1][3] = 10
a[2][0] = 2
a[2][1] = 0
a[2][2] = 8
a[2][3] = 0
a[3][0] = 0
a[3][1] = 10
a[3][2] = 8
a[3][3] = 10
a[4][0] = 2
a[4][1] = 2
a[4][2] = 10
a[4][3] = 8
total = 100
请按任意键继续. . .

解释:

①注意,对二维数组解除一次引用之后,是一维数组。例如int a[3][4]

其中a是二维数组的指针,坐标是a[0][0],长度是3*4int

*a是一维数组的指针,坐标是a[0][0],长度是4int

**a是数组中的一个成员的地址,坐标是a[0][0],长度是1int

 

②在give这个函数内部:

如节选代码:

void move(int a[][4], int m)
{
	cout << a << endl;	//指针,4个int宽度
	cout << a+1 << endl;	//指针偏移4个int宽度,4个int宽度
	cout << *(a + 1) << endl;	//指针偏移4个int宽度,1个int宽度
	cout << *(a + 1)+1 << endl;	//指针偏移4个int宽度,再偏移一个宽度,1个int宽度
	cout << *(*(a + 1) + 1) << endl;	//指针偏移4个int宽度,再偏移1个int宽度,然后指针所在位置的值
}

输出:


0027FCB4
0027FCC4
0027FCC4
0027FCC8
6

int宽度的(无论是一个还是四个),那么说明是地址,只是表示的宽度不同;

解除2次引用之后,则是值。

不解除引用的时候,是二维数组中的一个成员,又因为每个成员里有4int值,所以是4int宽度;

解除一次引用时,因为是二维数组一个成员中的四个成员 中的一个成员,是int类型的值,所以是1int宽度。


目录
相关文章
|
6月前
|
存储 算法 C语言
二维数组程序举例
二维数组程序举例
56 2
|
6月前
|
C语言
【C语言】利用数组处理批量数据(一维数组和二维数组)
【C语言】利用数组处理批量数据(一维数组和二维数组)
|
6月前
|
存储 C#
C#学习系列相关之数组(一)---数组的定义与使用
C#学习系列相关之数组(一)---数组的定义与使用
|
C语言
C语言之输出一个二维数组中,求每列最大的元素,并存放在另一个数组中
C语言之输出一个二维数组中,求每列最大的元素,并存放在另一个数组中
144 0
|
21天前
|
存储
如何使用指针数组来实现动态二维数组
指针数组可以用来实现动态二维数组。首先,定义一个指向指针的指针变量,并使用 `malloc` 为它分配内存,然后为每个子数组分配内存。通过这种方式,可以灵活地创建和管理不同大小的二维数组。
|
2月前
|
存储 人工智能 C语言
C语言程序设计核心详解 第六章 数组_一维数组_二维数组_字符数组详解
本章介绍了C语言中的数组概念及应用。数组是一种存储同一类型数据的线性结构,通过下标访问元素。一维数组定义需指定长度,如`int a[10]`,并遵循命名规则。数组元素初始化可使用 `{}`,多余初值补0,少则随机。二维数组扩展了维度,定义形式为`int a[3][4]`,按行优先顺序存储。字符数组用于存储字符串,初始化时需添加结束符`\0`。此外,介绍了字符串处理函数,如`strcat()`、`strcpy()`、`strcmp()` 和 `strlen()`,用于拼接、复制、比较和计算字符串长度。
|
5月前
|
C语言
C语言学习记录——矩阵转换(定义一个数组实现或定义两个数组实现)
C语言学习记录——矩阵转换(定义一个数组实现或定义两个数组实现)
56 0
|
6月前
|
C语言
【汇编语言实战】创建并遍历全部二维数组
【汇编语言实战】创建并遍历全部二维数组
47 0
|
6月前
|
C语言
【汇编语言实战】输出二维数组中特定元素
【汇编语言实战】输出二维数组中特定元素
23 0
|
存储 Java BI
Java数组(2)--一维数组
Java数组(2)--一维数组
124 1
Java数组(2)--一维数组