原文,转载如下:
这个和编译器有关 一维: cin>>n; int* a=new int[n]; 但是new出来的一定不要忘了delete掉 delete []a; // 正确的用法 delete a; // 错误的用法 后者相当于delete a[0],漏掉了另外n-1个对象。 二维: 设有m行n列 cin>>m>>n; int **a = new int* [m]; for(int i = 0; i < m; i++) a[i] = new int [n]; PS:就相当于产生了一个二维数组a[m][n]了,但是对于我们平时声明的数组a[m][n],a[i][j]=a[i*n+j],因为是连续的一片内存,而这样动态声明的数组任意的a[k] 都是一个int*类型,即一个地址了,所以只能a[i][j]或者*(*(a+i)+j)来访问数组的元素,而不能a[i*n+j]这样转换着用了 释放内存: for(int i = 0; i < m; ++i) delete []a[i]; delete []a; 对于c++,我们完全可以充分利用它自己强大而方便的容器,比如vector,之所以动态声明数组,相比是大小不确定,声明太大了怕浪费空间, 而vector就不用指定大小,当存的数据变多,自动扩大容量,比如假设vector默认大小是8,当你再往里存第9个元素时,容器自动扩容,变为16, 16再不够用,扩为32,2倍2倍的增长,这样就根据需要扩容,不会浪费空间,也可以像普通数组那样直接指定vector的大小,总之普通数组可以的它都可以, 普通数组没有的它更有; 一维: vector<int> a; a.push_back(k); k为待存入数组的数,用法一样,可以a[i]这样直接取数,还有各种自带的方法,使用方便极了 vector<int> a; vector<int> a(5); //指定数组大小是5 vector<int> a(5,3); //数组大小为5,并初始化数组所有元素值为3 二维: cin>>m>>n;//m行n列 vector<vector<int> > a(m, vector<int>(n)); //这行注意两个> >中间要加空格,否则会被认为是重载>>运算符 for (i = 0; i < m; i++) for (j = 0; j < n; j++) a[i][j] = i*j; for (i = 0; i < m; i++) for (j = 0; j < n; j++) cout<<a[i][j]<<' '; cout<<endl;