利用指针访问二维数组
数组名本身就具有指针的性质,因此我们在前面就知道实际上可以使用数组名当做地址使用,比如以下代码:
int a[100];
cout<<*(a+1);
实际上,本程序会输出数组第二位即1号位置上的数值,星号是一个指针运算符,用于将地址转换为相对应的值。
这样的性质也可以在二维数组甚至是多维数组中使用,比如:
#include<iostream>
#include<cstring>
using namespace std;
int main()
{
int ar[3][3] = {
{
10, 11, 12},{
20, 21, 22},{
30,31,32} };
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
cout << ar[i][j]<<" ";
}
cout << endl;
}
for (int i = 0; i < 3; i++)
{
for (int j = 0; j < 3; j++)
{
cout << *(*(ar + i)+j) << " ";
}
cout << endl;
}
cout << endl;
cout << *(*(ar + 1) + 1);
return 0;
}
以上例子中的ar+i实际上是一个行指针,指向这现在这一行所代表的数据,而外层的是一个列指针,指向的是这一行和这一列两个坐标所确定的数值。通过两个嵌套循环就可以实现将数组中的元素打印。
利用指针创建动态二维数组
之前也已经提到过可以使用new方法来创建一个动态的、长度可变的数组,在创建二维数组的时候,也可以使用new方法配合指针创建一个动态数组
#include<iostream>
using namespace std;
int main(){
int **p;
p = new int *[n];
for(int i = 0; i < n; i++)
{
p[i]=new int[m];
}
这样就可以获得一个n*m的二维动态数组