日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

C語言之關(guān)于二維數(shù)組在函數(shù)中的調(diào)用問題_C 語言

作者:紅飛機(jī)上的豬 ? 更新時間: 2022-09-05 編程語言

關(guān)于二維數(shù)組在函數(shù)中的調(diào)用問題

之前在學(xué)習(xí)二維數(shù)組的時候感覺理解起來很簡單,所以理解一下就過去了,但是當(dāng)自己真正的去用二維數(shù)組數(shù)組解決一些問題(特別是在函數(shù)調(diào)用二維數(shù)組的過程中)才真正發(fā)現(xiàn)原來使用起來還是要去注意一些細(xì)節(jié)的。廢話不多說,直接上干貨!

函數(shù)調(diào)用二維數(shù)組

在函數(shù)中調(diào)用二維數(shù)組的具體格式如下:

1、聲明:這是聲明的兩種格式,在這里定義的是一個N*5的二維字符數(shù)組,各位看官一定要注意,在聲明的過程中可是要將二維數(shù)組中第二個長度參數(shù)進(jìn)行標(biāo)明的呀。

2、定義:和聲明的格式?jīng)]有什么大的區(qū)別,只不過是要如果要采用第二種聲明方式的話要在定義時補(bǔ)充完整形參名

3、如果要去在函數(shù)中只使用二維數(shù)組中的其中一個一維數(shù)組時

我的個人做法是正常的在函數(shù)聲明中正常定義一個二維數(shù)組,之后再在函數(shù)申明中額外添加一個整數(shù)參數(shù)去來限定在函數(shù)中使用二維數(shù)組中具體哪一個一維數(shù)組,例子如下:

所寫這個函數(shù)是為了去分別算出這個二維數(shù)組中的每一個一維數(shù)組的平均值,所以我在定義函數(shù)時加了一個n來表示我要算哪一個一維數(shù)組的平均值。

4、在結(jié)構(gòu)體中千萬不要去使用二維數(shù)組?。。?/strong>

當(dāng)初我在寫結(jié)構(gòu)體是想當(dāng)然的去使用了二維數(shù)組,結(jié)果。。。

如果在使用結(jié)構(gòu)體的過程中需要用到類似于二維數(shù)組的儲存數(shù)據(jù)的特性時,我們應(yīng)當(dāng)去選取用結(jié)構(gòu)體數(shù)組來解決相應(yīng)的問題。結(jié)構(gòu)體數(shù)組相當(dāng)一二維數(shù)組的一維數(shù)組,結(jié)構(gòu)體中所定義的一些信息精細(xì)化相當(dāng)于二維數(shù)組中一維數(shù)組的信息。

好了,這就是我這個小白中的小白在實(shí)際使用的過程中所出現(xiàn)的一些情況。

?二維數(shù)組如何放到函數(shù)中使用

要想在函數(shù)中帶入一個二維數(shù)組

前提首先我們要知道二維數(shù)組在內(nèi)存中是如何分布的

假設(shè)定義一個二維數(shù)組 arr[3][3];

內(nèi)存中的是這樣儲存的:

圖解:

也就是說,二維數(shù)組的內(nèi)存關(guān)系是連續(xù)的,因此如果我們在函數(shù)中帶入一個數(shù)組只需要數(shù)組的第一排的第一個元素的地址和行數(shù)和列數(shù)三個條件

下面以一個二維矩陣的轉(zhuǎn)置為例

關(guān)鍵點(diǎn)是如何利用二維數(shù)組的第一排首元素的地址去把整個數(shù)組表示出來

假設(shè):

數(shù)組 int arr[3][3];

arr的值為第一排首元素地址

已知行列數(shù)為3,令int *p=arr;

可以用 *(p+i*3+j)表示第i排第j列的元素

因此函數(shù)只需要定義一個接收數(shù)組第一排首地址元素的指針類型的形參即可

下面見完整代碼:?

#include<stdio.h>
#include<windows.h>
void Array_transpose(int *arr, int rank)//rank為數(shù)組的列數(shù)  代表每排有多少個元素
{
	int i;
	int j;
	int temp;//temporary 臨時的
	for (i = 0; i < rank; i++)
	{
		for (j = 0; j < i; j++)
		{
			//交換沿著對角線對稱的兩個數(shù)的值
			//交換方法一
			/* *(arr + j * rank + i)=*(arr + j * rank + i)+*(arr + i * rank + j);   
			 *(arr + i * rank + j)=*(arr + j * rank + i)-*(arr + i * rank + j);   
			 *(arr + j * rank + i)=*(arr + j * rank + i)-*(arr + i * rank + j); */
			
			//交換方法二
			 *(arr + j * rank + i)=*(arr + j * rank + i)^*(arr + i * rank + j);
			 *(arr + i * rank + j)=*(arr + j * rank + i)^*(arr + i * rank + j);
			 *(arr + j * rank + i)=*(arr + j * rank + i)^*(arr + i * rank + j);
 
			//交換方法三
			/* temp = *(arr + j * rank + i);
			 *(arr + j * rank + i) = *(arr + i * rank + j);
			 *(arr + i * rank + j) =temp;*/
		}
	}
}
//配圖解:

 
int main()
{
	int a[5][5]=
	{
		0,0,1,0,0,
		0,0,1,0,0,
		0,0,1,0,0,
		0,0,1,0,0,
		0,0,1,0,0
 
	};
	int i, j,s;
	
	Array_transpose(a, 5);
 
		for (i = 0; i < sizeof(a)/sizeof(a[0]); i++)
		{
			//	 sizeof(a)/sizeof(a[0])得數(shù)組的有多少排
			for (j = 0; j < sizeof(a[0])/ sizeof(a[0][0]); j++)
 			//	 sizeof(a[0])/ sizeof(a[0][0])得到的是第一排的元素個數(shù)
			{
				if (a[i][j])
					printf("▇");
				else
				{
					printf("  ");
				}
			}
			printf("\n");
		}
	
	system("pause");
	return 0;
}

代碼實(shí)現(xiàn)的功能:

不使用Array_transpose()

原本輸出應(yīng)該是這樣

使用Array_transpose()

轉(zhuǎn)置后

利用代碼中的方法可以實(shí)現(xiàn)二維數(shù)組的轉(zhuǎn)置,可以作為俄羅斯方塊的色塊變化方向的基礎(chǔ)

原文鏈接:https://blog.csdn.net/qq_41022829/article/details/80452321