二维数组的认知

二维数组的定义和遍历

#include <stdio.h>

int array[2][2] = {{1,2},{3,4}};
int main()
{
	int i,j;
	for(i=0;i<2;i++){
		for(j=0;j<2;j++){
				printf("%d ",array[i][j]);
				printf("address:%p ",&array[i][j]);
		}
		putchar('\n');
	}	
	return 0;
}

例子:有一个3x4的矩阵,要求编程求出其中的最大值元素,以及其所在的行列号

#include <stdio.h>

int array[3][4] = {{1,2,47,8},{3,4,2,9},{3,5,9,0}};
int main()
{
	int Max;
	int hang,lie;
	int i,j;
	Max = array[0][0];
	for(i=0;i<3;i++){
		for(j=0;j<4;j++){
			if(Max < array[i][j]){
					Max = array[i][j];
					hang = i;
					lie = j;
			}				
		
	}
			
	}
	printf("Max=%d\n",Max);
	printf("%d行%d列\n",hang,lie);
	return 0;
}

二维数组地址的认知
1.数组名就是地址
2.二维数组本质还是数组,不同点就是数组元素还是个数组(子数组)
3.a[0] 既是一维数组名,也是该数组的a[0]中第0列元素的地址,即&a[0][0],也就是说例如a[1]的值是&a[1][0]

 关于二维数组地址的偏移
#include <stdio.h>

int main()
{
	int arr[3][4] ={{1,2,3,4},{5,6,7,8},{9,10,11,12}}; 
	
	printf("arr是父亲地址:%p,偏移1后的地址:%p\n",arr,arr+1);
	printf("arr[0]是子数组的地址:%p,偏移1后的地址是:%p %d  %d\n",arr[0],arr[0]+1,*arr[0],*arr[0]+1);
	printf("arr[0]是子数组地址:%p,偏移1后的地址:%p",*(arr+0),*(arr+0)+1);

	
	return 0;
}

在这里插入图片描述

二维数组的遍历

#include <stdio.h>

int main()
{
	int i,j;
	
	int arr[3][4] ={{1,2,3,4},{5,6,7,8},{9,10,11,12}}; 
	
	for(i=0;i<3;i++){
		for(j=0;j<4;j++){
			printf("add:0x%p,data:%d\n",&arr[i][j],arr[i][j]);
			printf("add:0x%p,data:%d\n",arr[i]+j,*(arr[i]+j));
			printf("add:0x%p,data:%d\n",*(arr+i)+j,*(*(arr+i)+j));
		}
		
	}

	
	return 0;
}

指针偏移的方法

#include <stdio.h>

int main()
{
	int i,j;
	
	int arr[3][4] ={{1,2,3,4},{5,6,7,8},{9,10,11,12}}; 
	
	int *p;
	p = &arr[0][0];

	for(i=0;i<3;i++){
		for(j=0;j<4;j++){
				printf("address:%p,data:%d\n",p,*p);
				p++;
		}
	}
	
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值