C++ - new delete 高维数组小结

借鉴:http://www.cnblogs.com/beyondstorm/archive/2008/08/26/1276278.html

   http://www.cnblogs.com/platero/archive/2010/12/18/1910057.html

高维数组的动态申请和释放与二维数组的类似,所以这里只演示的是二维数组的动态申请和释放。

先来个大众版的:

 1 #include <iostream>
 2
 3  using namespace std;
 4
 5 int main(void)
 6 {
 7         int **p;
 8
 9         p = new int*[3];
10
11         for (int i = 0; i < 3; i++)
12                 p[i] = new int[4];
13
14         for (int i = 0; i < 3; i++) {
15                 for (int j = 0; j < 4; j++)
16                         p[i][j] = i+j;
17         }
18
19         for (int i = 0; i < 3; i++)
20                 delete []p[i];
21
22         delete []p;
23
24         return 0;
25 }

  然后是各种new:

  

1. 
A (*ga)[n] = new A[m][n]; 
... 
delete []ga; 
缺点:n必须是已知 
优点:调用直观,连续储存,程序简洁(经过测试,析构函数能正确调用)

2. A** ga = new A*[m]; 
for(int i = 0; i < m; i++) 
ga[i] = new A[n]; 
... 
for(int i = 0; i < m; i++) 
delete []ga[i]; 
delete []ga; 
缺点:非连续储存,程序烦琐,ga为A**类型 
优点:调用直观,n可以不是已知

3. A* ga = new A[m*n]; 
... 
delete []ga; 
缺点:调用不够直观 
优点:连续储存,n可以不是已知

4. vector> ga; 
ga.resize(m); //这三行可用可不用 
for(int i = 1; i < n; i++) // 
ga[i].resize(n); // 
...

缺点:非连续储存,调试不够方便,编译速度下降,程序膨胀(实际速度差别不大) 
优点:调用直观,自动析构与释放内存,可以调用stl相关函数,动态增长

5. vectorga; 
ga.resize(m*n); 
方法3,4的结合

6. 2的改进版
A** ga = new A*[m]; 
ga[0] = new A[m*n]; 
for(int i = 1; i < m; i++) 
ga[i] = ga[i-1]+n; 
优点:连续存储,n可以不是已知,析构方便,猜想只需delete [] ga;

问题:

1.怎么进行多维数组的声明和初始化?

2.是否能够动态分配多维数组,怎么样正确析构?

3.怎么理解这些操作?

时间: 2024-10-03 05:30:35

C++ - new delete 高维数组小结的相关文章

Javascript数组小结

Javascript数组小结 Javascript将指定的数字索引值转换成字符串--索引值1变成"1"--然后将其作为属性名来使用. 数组的length修改后,数组中大于设定值的元素将被删除 数组的添加删除: 1)  修改length属性值(删除) 2)  push.pop在数组的尾部进行插入.删除操作并返回操作元素:unshift和shift()在数组的首部进行插入.删除操作 3)  delete可以删除数组元素,但它不会改变数组的length属性,只是将该值置空. 4)  spli

Es6中如何使用splic,delete等数组删除方法

Es6中如何使用splic,delete等数组删除方法 1:js中的splice方法 splice(index,len,[item])    注释:该方法会改变原始数组. splice有3个参数,它也可以用来替换/删除/添加数组内某一个或者几个值 index:数组开始下标        len: 替换/删除的长度       item:替换的值,删除操作的话 item为空 如:arr = ['a','b','c','d'] 删除 ----  item不设置 arr.splice(1,1)   /

C++ delete []p 数组指针,如何知道该数组大小的

本来只是一时兴起,想动手整整大学学的很渣的C++,可是一段小小的代码缺牵扯出一堆问题来,好有趣. 来看一段代码: void main() { char p[6]; char *buf = new char[4]; strcpy(buf,"012356789");//这里越界不会报错 strcpy(p,"Hello"); //若此处越界立即报错 cout<<p<<endl; cout<<buf<<endl; delete

matlab高维数组

对于高维数组,人们习惯地把二维数组的第一维称为"行(Row)",把第二维称为"列(column)",至于第三维,称谓都是不相同的这里为了方便,采用"页(Page)"来称呼. 打个比方,二维数组可以看成由"小方格"拼成的"矩面行"那样,三维数组可以被看成由"小方块"组成的"长方体".对于三维数组来说,无论在那一页的二维行.列数组都应该是同样大小的:无论哪一行上的二维列.

C++ 之 Vector(容器)初始化高维数组

使用C++标准模版库(STL)中的Vector(向量)可以实现变长数组,实现二维数组,高维数组.下面给出代码实现. #include<iostream> #include<vector> using namespace std; int main() { int len; cin>>len; vector<int> array(len);//声明变长数组 for(int i=0;i<len;i++) array[i]=i; cout<<ar

js数组小结

1.js数组使用sort()排序 var a = ["1","12","3","4","0"]; document.write(a.sort(function(a,b){ //实现升序排序 return a - b; })); 2.js使用数组实现一些数据结构 栈        push() , pop() 队列 shift() ,  push() 反向队列    unshift() , pop() 其中

树状数组小结

树状数组基本概念 树状数组也是进行区间操作的常用数据结构.树状数组适用于单个元素经常修改,而且还反复求部分的区间和的情况. 对于数组a,构造一个新的数组C,使得C[i] = a[i-2^k+1] + a[i-2^k+2] + ... + a[i]; (1) i >= 1: (2) k为i在二进制表示下末尾的连续的0的个数,2^k = i&(-i),通常用lowbit(i)表示i对应的2^k,lowbit(i) = 2^k = i&(-i): 则数组C为数组a的树状数组. 数组数组的结

数组小结

数组 一.     引言 为什么需要数组呢?有时候需要存储或处理一系列数据,数组就可以充当这样的角色,它在内存中是相连的数据,并且在栈中的引用只有一个,如果不用数组,那数据就得一个一个定义一个一个声明,浪费内存空间,显然不合理. 二.       定义 变量:存储单个元素的内存空间 数组:存储多个元素的连续的内存空间,相当于多个变量的集合 数组名的索引 1.     索引:编号从0开始,属于数值索引 2.     注意:索引可支持使用自定义的格式,而不仅仅是数值格式,即为关联索引,bash4.0

后缀数组小结

后缀数组又被称为字符串处理神器: http://blog.csdn.net/xymscau/article/details/8798046 这里讲的非常好 实现rank排名是用到了倍增法和一个比较神奇的计数排序,时间复杂度是nlongn height[i]存放的是排名第i的后缀与排名第i-1的后缀的最长前缀, sa[i]存的是排名第i的后缀是第几位开头的 rk[i]存放第i个位置开头的后缀的字典序排名 1.poj2774(后缀数组水题) 题意:给你两串字符,要你找出在这两串字符中都出现过的最长子