指针数组[1]
- 数组的元素是指针型
这里定义了一个指向point类的指针数组,它有两个元素组成,这两个元素都是指向point对象的指针。
问:定义二维数组不好吗?干吗要定义指针数组呢?
答:其实二维数组相当于由一维数组构成的数组。如果想存放若干行长长短短不一样的信息
时,用二维数组就不方便了。因为二维数组规定每一行的列的长度是一样的。
例6-8 利用指针数组存放矩阵
#include <iostream>
using namespace std;
int main() {
int line1[] = { 1, 0, 0 }; //矩阵的第一行
int line2[] = { 0, 1, 0 }; //矩阵的第二行
int line3[] = { 0, 0, 1 }; //矩阵的第三行
//定义整型指针数组并初始化
int *pLine[3] = { line1, line2, line3 };
cout << "Matrix test:" << endl;
//输出矩阵
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 3; j++)
cout << pLine[i][j] << " ";
cout << endl;
}
return 0;
}
指针数组与二维数组对比
- 对比例6-8中的指针数组和如下二维数组
int array2[3][3] ={ { 1,0,0 }, { 0,1,0 }, { 0,0,1 } };
- 如果定义的是二维数组,它的所有元素是按行依次连续存放的。
- 如果定义的是指针数组,它的每一个指针元素指向一个其他的数组。
指针数组的指针所指向的数组并不是依次连续存放的,或者说不见得依次连续存放。也就是说行与行之间可能它就不是依次连续的,这就是指针数组和二维数组的核心差别。
参考
- ^http://www.xuetangx.com/courses/course-v1:TsinghuaX+00740043X_2015_T2+sp/courseware/d4eb7d174ba04a4da6282bcae197892c/a58465c9cbbb4e15a08588cc114b5796/